当前位置:首页 » 编程语言 » sqlserver函数
扩展阅读
webinf下怎么引入js 2023-08-31 21:54:13
堡垒机怎么打开web 2023-08-31 21:54:11

sqlserver函数

发布时间: 2022-01-12 07:25:36

A. sqlServer常用函数

1、CONVERT()
函数
?
1
CONVERT(data_type(length),data_to_be_converted,style)
data_type(length)
规定目标数据类型(带有可选的长度)。data_to_be_converted
含有需要转换的值。style
规定日期/时间的输出格式。
可以使用的
style
值:点击打开链接
2、DATEADD()
函数
点击打开链接
3、CAST()
函数
?
1
2
Syntax
for
CAST:
CAST
(
expression
AS
data_type
[
(
length
)
]
)
expression
任何有效的表达式。
data_type
目标数据类型。
这包括
xml、bigint

sql_variant。
不能使用别名数据类型。
length
指定目标数据类型长度的可选整数。
默认值为
30。
CONVERT()
函数与CAST()
函数详细信息:点击打开链接

B. SqlServer函数的系统函数

newid 无参数
返回一个GUID(全局唯一表示符)值
例如:select newid()
返回:2E6861EF-F4DB-4FFE-86EB-637482FE982J2
isnumeric (任意表达式)
判断表达式是否为数值类型或者是否可以转换成数值。
是:返回1,不是:返回0
例如:select isnumeric(1111) 返回 1
select isnumeric('123rr') 返回 0
select isnumeric('123') 返回 1
isnull (任意表达式1,任意表达式2)
如果任意表达式1不为NULL,则返回它的值;否则,在将任意表达式2的类型转换为任意表达式1的类型(如果这两个类型不同)后,返回任意表达式2的值。
例如:select isnull(null,N'没有值') 返回 没有值
select isnull(N'具体的值',N'没有值') 返回 具体的值
isdate (任意表达式)
确定输入表达式是否为有效日期或可转成有效的日期;
是:返回1,不是:返回0
例如:select isdate(getdate()) 返回1
select isdate('2013-01-02') 返回1
select isdate('198') 返回0

C. sqlserver 按范围取值的函数

你可以试试CASE WHEN,具体(case when sum(A)<=200 then 200 when sum(A)>=300 then 300 else B end) as B

D. SqlServer函数的字符串函数

1 字符串函数
1.1 长度与分析用
datalength(Char_expr) 返回字符串包含字符数,但不包含后面的空格
substring(expression,start,length) 不多说了,取子串
right(char_expr,int_expr) 返回字符串右边int_expr个字符
1.2 字符操作类
upper(char_expr) 转为大写
lower(char_expr) 转为小写
space(int_expr) 生成int_expr个空格
replicate(char_expr,int_expr)复制字符串int_expr次
reverse(char_expr) 反转字符串
stuff(char_expr1,start,length,char_expr2) 将字符串char_expr1中的从
start开始的length个字符用char_expr2代替
ltrim(char_expr) rtrim(char_expr) 取掉空格
ascii(char) char(ascii) 两函数对应,取ascii码,根据ascii码取字符
1.3 字符串查找
charindex(char_expr,expression) 返回char_expr的起始位置
patindex(%pattern%,expression) 返回指定模式的起始位置,否则为0

E. SQLServer里用户自定义函数写在哪

drop FUNCTION [dbo].[jzf_Get_IDNO]

go

-- =============================================

-- Author: <Author,,Name>

-- Create date: <Create Date, ,>

-- Description: <Description, ,>

-- =============================================

create FUNCTION [dbo].[jzf_Get_IDNO]

(

-- Add the parameters for the function here

@ApartID nvarchar(40)

)

RETURNS nvarchar(40)

AS

BEGIN

-- Declare the return variable here

DECLARE @str nvarchar(40)

set @str=N'未查到'

-- Add the T-SQL statements to compute the return value here

SELECT @str=Isnull(IDNO,N'未定义') from mytable where objectid=@ApartID


-- Return the result of the function

RETURN @str


---------------------结果显示在,上述函数是标量值函数:

F. SqlServer函数的聚合函数

count()
返回组中的总条数,count(*)返回组中所有条数,包括NULL值和重复值项,如果抒写表达式,则忽略空值,表达式为任意表达式。
max()
返回组中的最大值,空值将被忽略,表达式为数值表达式,字符串表达式,日期。
min()
返回组中的最小值,空值将被忽略,表达式为数值表达式,字符串表达式,日期。
sum()
返回组中所有值的和,空值将被忽略,表达式为数据表达式。
avg()
返回组中所有值的平均值,空值将被忽略,表达式为数据表达式。

G. sqlserver 查看自定义函数


惨了,好像答非所问了。

H. SqlServer函数的数学函数

trunc(45.923,1) 按指定精度截断十进制数 结果:45.9 此为oracle函数
mod(1600,300) 求除法余数 结果:100
abs(numeric_expr) 求绝对值
ceiling(numeric_expr) 取大于等于指定值的最小整数
avg(numeric_expr)取平均数
exp(float_expr) 取指数
floor(numeric_expr) 小于等于指定值得最大整数
pi() 3.1415926.........
power(numeric_expr,power) 返回power次方
rand([int_expr]) 随机数产生器
round(numeric_expr,int_expr) 安int_expr规定的精度四舍五入
sign(int_expr) 根据正数,0,负数,,返回+1,0,-1
sqrt(float_expr) 平方根

I. sqlserver 函数的写法

returns @RowSet table(
ID int identity(1,1) ,
score float,
lastScore float
)
你这里已经声明了一个表格类型变量作为函数的返回值.
那么只要在函数里对这个表进行赋值,就可以直接return

insert into @RowSet values(...)
return
--------
declare @ScoreList table (YScore float)
declare @ScoreList1 table (lastScore float)
-------------------------------------------

怎么我看你又声明了两个表格类型的变量?你函数声明里的返回类型是表,那么单行返回的话就只能往里装简单类型的值.
如果你要union拼接两个table一起返回的话,两个内部table和声明的返回table定义又不一致.
很奇怪的写法...能看出来你想干什么...但这种写法很怪异.
========================================补充
insert into @ScoreList SELECT...
insert into @ScoreList1 SELECT ...
你这不是把两个查询的结果赋给两个内部变量了么,且这个表与你声明的返回表都是一个float列.
你完全可以再把这两个变量表insert 到@RowSet啊,或者不用这俩变量表,直接在两个查询里向@RowSet写入值.
最后直接
return
end
不就行了?
======
http://hi..com/kas68310/blog/item/af4e05f0d5ee18c50a46e012.html
这有个返回值为talble的函数,你参看一下吧.你这个函数的完成度已经相当高了.

J. SqlServer如何用Sql语句自定义聚合函数

有两个写法:

select*fromtblDept
whereidin(
count(casewhenSalary>3000then1elsenullend)*1.0/count(*)>0.5)

select*fromtblDept
whereidin(
sum(casewhenSalary>3000then1else0end)*1.0/count(*)>0.5)