SQL常用函数集

SQL,函数对数据或数据组执行操作,然后返回需要的值

函数表达式可以出现在SELECT列表中,或者在任何允许出现的位置上

SQL包含了七种函数:

(1)聚合函数:返回汇总值

(2)转型函数:将一种数据类型转换为另外一种

(3)日期函数:处理日期和时间

(4)数学函数:执行算术运算

(5)字符串函数:对字符串二进制数据或表达式执行操作

(6)系统函数:从数据库返回在SQLSERVER中的值对象或设置的特殊信息

(7)文本和图像函数:对文本和图像数据执行操作

 

 1聚合函数:它对其应用的每个行集返回一个值

函数        返回值

AVG(表达式) 返回表达式中所有的平均值仅用于数字列并自动忽略NULL

COUNT(表达式) 返回表达式中非NULL值的数量可用于数字和字符列

COUNT(*) 返回表中的行数(包括有NULL值的列)

MAX(表达式) 返回表达式中的最大值,忽略NULL可用于数字字符和日期时间列

MIN(表达式) 返回表达式中的最小值,忽略NULL可用于数字字符和日期时间列

SUM(表达式) 返回表达式中所有的总和,忽略NULL仅用于数字列

 2转换函数:CONVERTCAST两种

CONVERT实例: Select convert(varchar(10) ,stuno) as stuno,stuname from student

CAST实例: Select cast(stuno as varchar(10)) as stuno,stuname from student

注意:

1)如果没有指定表达式转换后的所得到的数据类型的长度,SQLSERVER自动提供的长度为

2)转换为位(bit)类型时,会将任何非零值转换为

3)转换为moneysmallmoney类型时,假定货币单位为整数

4)仅当charvarchar数据类型表示数字时,可以转换为整数数据类型

5)charvarchar数据类型转换为money类型时,可包含小数点和美元符号($)

6)charvarchar数据类型转换为浮点或实数类型时,可包含指数符号

7)如果对新的数据类型的而言值过长,则值将被截断

8)可以显示的方法将Text列转换为charvarchar,以及将image列转换为binaryvarbinary但是,不能超过个字符

 

3日期函数

      由于不能直接执行算术函数,所以日期函数就十分有用

它可以帮助您析取出日期值中的天月和年,这样就可以分别处理它们

SQL,日期的表示方法及有效范围,如下:

日期部分 缩写        日期部分 缩写

       yy 1753-9999         wk 1-53

季度     qq 1-4        小时     hh 0-23

       mm 1-12       分钟     mi 0-59

一年中的天 dy 1-366           ss 0-59

一月中的天 dd 1-31     毫秒     ms 0-999

一周中的天 dw 1-7  

 

 日期函数如下:

函数 返回值

GETDATE 当前的系统日期

DATEADD(日期部分,number,date) 返回带有指定数字(number)的日期(date),该数字添加到指定的日期部分(datepart)

DATEDIFF(日期部分,date1,date2) 返回两个日期中指定的日期部分之间的差值

DATENAME(日期部分,date) 返回日期中日期部分的字符串形式

DATEPART(日期部分,date) 返回日期中指定的日期部分的整数形式

YEAR(date) 返回指定日期的年份数值

MONTH(date)返回指定日期的月份数值

DAY(date)返回指定日期的天数值

 

当显示日期列的内容时如果只显示年月日部分,可以使用CONVERT转换函数对日期列进行转换

CONVERT(VARCHAR(10),日期字段名,120) --120 为日期格式YYYY-MM-DD

SELECT CONVERT(VARCHAR(10),盘点日期,120)  AS 盘点日期 FROM 原材料盘点日期明细表

 

4数字函数:对数字值执行代数运算

ABS(num_expr) 返回数值表达式的绝对值

ACOS(float_expr) 返回角(以弧度表示),它的余弦值近似于指定的浮点表达式

ASIN(float_expr) 返回角(以弧度表示),它的正弦值近似于指定的浮点表达式

ATAN(float_expr) 返回角(以弧度表示),它的正切值近似于指定的浮点表达式

ATN2(float_expr1, float_expr2) 返回角(以弧度表示),它的正切值在两个近似的浮点表达式之间

CEILING(num_expr) 返回大于或等于数值表达式的最小整数

COS(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的余弦三角函数的值

COT(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的余切三角函数的值

DEGREES(num_expr) 返回数值表达式表示的弧度值对应的度值

EXP(float_expr) 根据指定的近似浮点表达式,返回指数值

FLOOR(num_expr) 返回小于或等于数值表达式的最大整数

LOG(float_expr) 根据指定的近似浮点表达式,返回自然对数值

LOG10(float_expr) 根据指定的近似浮点表达式,返回以为底的对数

PI() 返回常量值.141592653589793

POWER(num_expr,y) 返回幂为y的数值表达式的值

RADIANS(num_expr) 返回数值表达式表示的度值对应的弧度值

RAND([seed]) 随机返回的到之间的近似浮点值,可以对seed指定为整数表达式(可选)

ROUND(num_expr,length) 对数值表达式截取指定的整数长度,返回四舍五入后的值

SIGN(num_expr) 对正数执行+1操作,对负数和零执行-1操作

SIN(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的正弦三角函数的值

SQUARE(float_expr) 返回浮点表达式的平均值

SQRT(float_expr) 返回指定的近似浮点表达式的平方根

TAN(float_expr) 返回以浮点表达式表示的近似于指定角度(以弧度表示)的正切三角函数的值

5字符串函数:可用于binary varbinary数据类型列,但主要用于charvarchar数据类型

Expr1+expr2 返回两个表达式的组合形式的字符串

ASCII(char_expr) 返回表达式最左边字符的ASC代码值

CHAR(int_expr) 返回到之间的整数表达式的ASC字符值如果输入的值不在有效范围内,则返回NULL

CHARINDEX('pattern',char_expr) 返回字符表达式中指定模式的起始位置

DIFFERENCE(char_expr1,char_expr2) 根据比较两个字符表达式的相似度,返回到之间的值表示匹配度最佳

LEN(char_expr) 返回字符表达式的长度

LOWER(char_expr) 将字符表达式全部转换为小写

LTRIM(char_expr) 返回删除掉前面空格的字符表达式

PATINDEX('%pattern%',expr) 返回表达式中模式第一次出现的起始位置返回表示不存在模式形式

REPLICATE(char_expr,int_expr) 返回重复指定次数的字符表达式产生的字符串

REVERSE(char_expr) 反转字符表达式

RIGHT(char_expr,int_expr) 返回从字符表达式最右端起根据指定的字符个数得到的字符

RTRIM(char_expr) 返回删除掉其后空格的字符表达式

SOUNDEX(char_expr) 评估两个字符串的相似度后得到的位代码

SPACE(int_expr) 返回包含指定空格数的字符串

STR(float_expr[,length[,decimal]]) 返回浮点表达式的字符串表示法。

STUFF(char_expr1,start,length,char_expr2) 使用字符表达式替换字符表达式的一部分字符,从指定的位置开始替换指定的长度

SUBSTRING(char_expr,start,length) 返回从字符表达式的指定位置开始,截取指定长度得到的字符集

UPPER(char_expr) 将字符表达式全部转换为大写

6系统函数:用于返回元数据或配置设置

COALESCE(expr1,expr2, xprN) 返回第一个非NULL表达式

COL_LENGTH('table_name','column_name') 返回列的长度

COL_NAME(table_id,column_id) 返回指定的表中的列名

DATALENGTH('expr') 返回任何数据类型的实际长度

DB_ID([‘database_name']) 返回数据库的标识号

DB_NAME([database_id]) 返回数据库的名称

GETANSINULL([‘database_name']) 返回数据库的默认空性(Nullability)

HOST_ID() 返回工作站的标识号

HOST_NAME() 返回工作站的名称

IDENT_INCR('table_or_view') 有新的记录添加入到表中时计数加

IDENT_SEED('table_or_view') 返回标识列的起始编号

INDEX_COL('table_name',index_id,key_id) 返回索引的列名

ISNULL(expr,value) 使用指定的值替换的NULL表达式

NULLIF(expr1,expr2) Expr1Expr2相等时,返回Null

OBJECT_ID('obj_name') 返回数据库对象标识号

OBJECT_NAME('object_id') 返回数据库对象名

STATS_DATE(table_id,index_id) 返回上次更新指定索引的统计的日期

SUSER_SID([‘login_name']) 返回用户的登录标识号

SUSER_ID([‘login_name']) 返回用户的登录标识号这个函数类似于SUSER_SID()函数,并且保留了向后的兼容性

SUSER_SNAME([server_user_id]) 返回用户的登录标识号

SUSER_NAME([server_user_id]) 返回用户的登录标识号这个函数类似于SUSER_SNAME()函数,并且保留了向后的兼容性

USER_ID('user_name') 返回用户的数据库标识号

USER_NAME(['user_id']) 返回用户的数据库名称

 

 7文本和图像函数:通常返回有关文本和图像数据所需的信息文本和图像数据是以二进制格式的形式进行存储的

TEXTPTR(col_name) 返回varbinary格式的文本指针值对文本指针进行检查以确保它指向第一个文本页

TEXTVALID('table_name.col_name',text_ptr)检查给定的文本指针是否有效返回表示有效,返回表示指针无效

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值