SQL中包含以下七种类型的函数:

  1. 聚合函数:返回汇总值。
  2. 转型函数:将一种数据类型转换为另外一种。
  3. 日期函数:处理日期和时间。
  4. 数学函数:执行算术运算。
  5. 字符串函数:对字符串、二进制数据或表达式执行操作。
  6. 系统函数:从数据库返回在SQLSERVER中的值、对象或设置的特殊信息。
  7. 文本和图像函数:对文本和图像数据执行操作。

一、聚合函数 (它对其应用的每个行集返回一个值。)

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

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

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

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

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

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

二、转换函数

有CONVERT和CAST两种。

  • CONVERT(data_type[(length)], expression [, style])

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

  • CAST( expression AS data_type )

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

Cast和Convert的区别

Cast 和Convert都是用来将一种数据类型的表达式转换为另一种数据类型的表达式。CAST 和 CONVERT 提供相似的功能,只是语法不同。在时间转化中一般用到convert,因为它比cast多加了一个style,可以转化成不同时间的格式。

三、日期函数

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

GETDATE() 当前的系统日期。

例:select GETDATE() --结果:2019-05-07 18:34:27.343

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

例:select DATEADD(dd, 5, getdate()) --增加5天时间

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

例:select DATEDIFF(mm, '2010-1-1', '2010-3-1 00:00:00') --结果:2

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

例:select DATENAME(dw,GETDATE()) --结果:星期二

注:DATENAME 和 DATEPART 的区别,返回的值类型不同,一个是VARCHAR一个是INT,另外就是星期会用本地语言来表示

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

例:select DATEPART(dw,GETDATE()) --结果(返回今天是一周中的第几天):3

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

例:select YEAR(GETDATE()) --结果:2019

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

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

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

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

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

四、数字函数

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

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

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

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

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

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

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

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

五、字符串函数

可用于binary 和varbinary数据类型列,但主要用于char和varchar数据类型。

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) 将字符表达式全部转换为大写。

六、系统函数

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

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

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

NULLIF(expr1,expr2) Expr1与Expr2相等时,返回Null。

七、文本和图像函数

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

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

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

最新文章

  1. android studio 集成微信登录
  2. 安装openssl 扩展的时候出现Cannot find config.m4. Make sure that you run '/usr/local/php/bin/phpize' in the top level source directory of the module的解决方法
  3. Java与MySQL的连接
  4. ECshop后台角色权限的添加和分配
  5. 图片缩放应用(nearest / bilinear / three-order interpolate)
  6. Linux系统编程-setitimer函数
  7. java多线程-CountDownLatch
  8. 工作空间项目不存在,eclipse中项目删不掉
  9. 在 Ubuntu 14.04/15.04 上配置 Node JS v4.0.0
  10. 应用XML作为数据库的快速开发框架
  11. Git CMD - clone: Clone a repository into a new directory
  12. 【手机走 ipv6】
  13. css3 旋转出现动画
  14. 从本地上传整个目录到hdfs的java程序
  15. 2-路插入排序(2-way Insertion Sort)的C语言实现
  16. 现代控制理论习题解答与Matlab程序示例
  17. openstack项目【day23】:keystone组件基础
  18. python module -- sys
  19. faiss索引基于数量级和内存限制的选择
  20. 获取Vue的实例方法

热门文章

  1. mybatis-plus自动填充
  2. CountDownLatch(减少计数)
  3. Java基础之字面值
  4. SQL SERVER迁移--更换磁盘文件夹
  5. 4G DTU模块和串口设备连接的方式
  6. Oracle终极彻底卸载
  7. python开发--基础知识-(持续更新)
  8. Thinkphp3.2 cms之登陆模块
  9. stm32与地磁传感器HMC5883L
  10. Spider_基础总结4_bs.find_all()与正则及lambda表达式