函数整理(T-SQL 版)

一、数学函数

  1.求绝对值

  ABS() 函数用来返回一个数值的绝对值。

SELECT ABS(-5.38) AS absValue;

  

  2.求指数

  POWER()  函数是用来计算指数的函数。该函数接受两个参数,第一个参数为待求幂的表达式,第二个参数为幂。

SELECT POWER(5, -0.5) AS powerValue1,
POWER(5, 2) AS powerValue2,
POWER(5, 3) AS powerValue3;

  3.求平方根

  SQRT()  函数是用来计算平方根的函数。该函数接受一个参数,这个参数为待计算平方根的表达式。

SELECT SQRT(9) AS sqrtValue1,
SQRT(3) AS sqrtValue2;

  

  4.求随机数

SELECT RAND(9527) randValue;

  5.舍入到最大整数

SELECT CEILING(56.67) ceilingValue1,
CEILING(-56.67) ceilingValue2;

  6.舍入到最小整数

SELECT FLOOR(56.67) floorValue1,
FLOOR(-56.67) floorValue2;

  7.四舍五入

  ROUND()  函数也是用来进行数值四舍五入的。

SELECT ROUND(56.67, 0) roundValue1,
ROUND(56.67, 1) roundValue2,
ROUND(-56.67, 0) roundValue3;

  8.求正弦值

SELECT SIN(56.67) sinValue;

  9.求余弦值

SELECT COS(56.67) cosValue;

  10.求反正弦值

SELECT 1 / 56.67,
ASIN(1 / 56.67) asinValue;

  11.求反余弦值

SELECT 1 / 56.67,
ACOS(1 / 56.67) acosValue;

  12.求正切值

SELECT TAN(56.67) tanValue;

  13.求反正切值

SELECT ATAN(56.67) atanValue;

  14.求 2 个变量的反正切

SELECT ATN2(56.67, 2) atn2Value;

  15.求余切

SELECT COT(56.67) cotValue;

  16.求圆周率 π 值

SELECT PI() 'pi';

  17.弧度制转换为角度制

SELECT DEGREES(56.67) degreesValue;

  18.角度制转换为弧度制

SELECT RADIANS(56.67) radiansValue;

  19.求符号

  SIGN() 函数用来返回一个数值的符号,如果数值大于 0 则返回 1,如果数值等于 0 则返回 0,如果数值小于 0 则返回-1。

SELECT SIGN(1 - 3) signValue1,
SIGN(3 - 1) signValue2,
SIGN(0) signValue3;

  20.求自然对数

  LOG() 函数用来计算一个数的自然对数值。

SELECT LOG(56.67) logValue;

  21.求以 10 为底的对数

SELECT LOG10(56.67) log10Value;

二、字符串函数

  1.计算字符串长度

SELECT LEN('abc');

  2.字符串转换为小写

SELECT LOWER('A');

  3.字符串转换为大写

SELECT UPPER('a');

  4.截去字符串左侧空格

SELECT LTRIM(' a ');

  5.截去字符串右侧空格

SELECT RTRIM(' a ');

  6.截去字符串两侧的空格

SELECT RTRIM(LTRIM(' a '));

  7.取子字符串

  SUBSTRING(string, start_position, length)

SELECT 'abcdef',
SUBSTRING('abcdef', 2, 3);

  8.计算子字符串的位置

SELECT CHARINDEX('ly', 'Kelly'),
CHARINDEX('m', 'Smith');

  9.从左侧开始取子字符串

  LEFT(string, length)

SELECT LEFT('abcdef', 3);

  10.从右侧开始取子字符串

  RIGHT(string,length)

SELECT RIGHT('abcdef', 3);

  11.字符串替换

  REPLACE(string, string_tobe_replace, string_to_replace)

SELECT REPLACE(' abc def', ' ', '');

  12.得到字符的 ASCII 码

  ASCII() 函数用来得到一个字符的 ASCII 码,它有且只有一个参数,这个参数为待求 ASCII 码的字符,如果参数为一个字符串则函数返回第一个字符的 ASCII 码。

SELECT ASCII('a'),
ASCII('abc');

  13.得到一个 ASCII 码数字对应的字符

  与 ASCII() 函数正好相反,获取得到一个字符的 ASCII 码。

SELECT CHAR(56) char1,
CHAR(90) char2,
CHAR(ASCII('a')) char3;

  14.转换为整数

SELECT CEILING(90.021) ceilingValue;

  15.发音匹配度

  有的时候我们并不知道一个人姓名的准确拼写,只知道它的发音,这是在公安、医疗、教育等系统中是经常需要的功能。

SELECT SOUNDEX('jack') jackSoundexValue,
SOUNDEX('jeck') jeckSoundexValue,
SOUNDEX('joke') jockSoundexValue,
SOUNDEX('juke') jukeSoundexValue,
SOUNDEX('look') lookSoundexValue,
SOUNDEX('jobe') jobeSoundexValue;

  DIFFERENCE() 用来简化两个字符串的发音相似度比较,它可以计算两个字符串的发音特征值,并且比较它们,然后返回一个 0 至 4 之间的一个值来反映两个字符串的发音相似度,这个值越大则表示两个字符串发音思想度越大。

SELECT DIFFERENCE('Kerry', 'Merry') diffValue1,
DIFFERENCE('Jim', 'Merry') diffValue2;

三、日期时间函数

  1.取得当前日期时间的函数 GETDATE()

SELECT GETDATE();
SELECT CONVERT(VARCHAR(50), GETDATE(), 101) AS 当前日期,
CONVERT(VARCHAR(50), GETDATE(), 108) AS 当前时间;

  2.日期增减

SELECT GETDATE(),
DATEADD(YEAR, 3, GETDATE()) AS time1,
DATEADD(QUARTER, 20, GETDATE()) AS time2,
DATEADD(MONTH, 68, GETDATE()) AS time3,
DATEADD(WEEK, -1000, GETDATE()) AS time4;

  3.计算日期差额

SELECT GETDATE(),
DATEDIFF(YEAR, '1992-06-01 00:00:00', GETDATE()) '年份',
DATEDIFF(QUARTER, '1992-06-01 00:00:00', GETDATE()) '季度',
DATEDIFF(MONTH, '1992-06-01 00:00:00', GETDATE()) '月份',
DATEDIFF(DAYOFYEAR, '1992-06-01 00:00:00', GETDATE()) '每年的某一日',
DATEDIFF(DAY, '1992-06-01 00:00:00', GETDATE()) '日期',
DATEDIFF(WEEK, '1992-06-01 00:00:00', GETDATE()) '星期',
DATEDIFF(WEEKDAY, '1992-06-01 00:00:00', GETDATE()) '工作日',
DATEDIFF(HOUR, '1992-06-01 00:00:00', GETDATE()) '小时',
DATEDIFF(MINUTE, '1992-06-01 00:00:00', GETDATE()) '分钟',
DATEDIFF(SECOND, '1992-06-01 00:00:00', GETDATE()) '秒';

  4.计算一个日期是星期几

SELECT GETDATE(),
DATENAME(YEAR, GETDATE()) '年份',
DATENAME(QUARTER, GETDATE()) '季度',
DATENAME(MONTH, GETDATE()) '月份',
DATENAME(DAYOFYEAR, GETDATE()) '每年的某一日',
DATENAME(DAY, GETDATE()) '日期',
DATENAME(WEEK, GETDATE()) '星期',
DATENAME(WEEKDAY, GETDATE()) '工作日',
DATENAME(HOUR, GETDATE()) '小时',
DATENAME(MINUTE, GETDATE()) '分钟',
DATENAME(SECOND, GETDATE()) '秒',
DATENAME(MILLISECOND, GETDATE()) '毫秒';

  5.取得日期的指定部分

  DATEPART()  函数的返回值是数字而 DATENAME()  函数则会将尽可能的以名称的方式做为返回值。

SELECT GETDATE(),
DATEPART(YEAR, GETDATE()) '年份',
DATEPART(QUARTER, GETDATE()) '季度',
DATEPART(MONTH, GETDATE()) '月份',
DATEPART(DAYOFYEAR, GETDATE()) '每年的某一日',
DATEPART(DAY, GETDATE()) '日期',
DATEPART(WEEK, GETDATE()) '星期',
DATEPART(WEEKDAY, GETDATE()) '工作日',
DATEPART(HOUR, GETDATE()) '小时',
DATEPART(MINUTE, GETDATE()) '分钟',
DATEPART(SECOND, GETDATE()) '秒',
DATEPART(MILLISECOND, GETDATE()) '毫秒';

四、其他函数

  1.类型转换

  CAST ( expression AS data_type)

  CONVERT ( data_type, expression)

SELECT CAST('-30' AS INT) AS v1,
CONVERT(DECIMAL, '3.1415726') AS v2,
CONVERT(DATETIME, '2008-08-08 08:09:10') AS v3;

  2.空值处理

  COALESCE ( expression, value1, value2……, valuen)

SELECT COALESCE('', GETDATE()) v1,
COALESCE(NULL, GETDATE()) v2,
COALESCE(NULL, '2008-08-08', GETDATE()) v3;

  NULLIF() 函数

  NULLIF ( expression1, expression2 )

DECLARE @nullIfExpression DATETIME = NULL;
SELECT NULLIF('1981-03-22 00:00:00.0', GETDATE()) v1,
NULLIF(GETDATE(), '1981-03-22 00:00:00.0') v2,
NULLIF(@nullIfExpression, GETDATE()) v3,
NULLIF(GETDATE(), @nullIfExpression) v4,
NULLIF(@nullIfExpression, @nullIfExpression) v5;

  3.CASE 函数

  CASE expression
  WHEN value1 THEN returnvalue1
  WHEN value2 THEN returnvalue2
  WHEN value3 THEN returnvalue3
  ……
  ELSE defaultreturnvalue
  END

  

DECLARE @caseName NVARCHAR(100) = 'TONY';
SELECT (CASE @caseName
WHEN 'TONY' THEN
'Tony'
WHEN 'MILI' THEN
'MiLi'
ELSE
'Other'
END
) AS Name;

DECLARE @caseAge INT = 20;
SELECT (CASE
WHEN @caseAge > 60 THEN
'老人'
WHEN @caseAge > 30 THEN
'中年'
WHEN @caseAge >= 18 THEN
'壮丁'
ELSE
'小屁孩'
END
) AS '称谓';

  4.PATINDEX() 函数

SELECT 'Tom',
PATINDEX('%_m%', 'Tom')
UNION
SELECT 'Lily',
PATINDEX('%_m%', 'Lily');

  5.REPLICATE() 函数

SELECT 'Jim',
REPLICATE('Jim', 1)
UNION
SELECT 'Tony',
REPLICATE('Tony', 2);

  6.REVERSE() 字符串颠倒

SELECT 'Jim',
REVERSE('Jim')
UNION
SELECT 'Tony',
REVERSE('Tony');

  7.ISDATE() 函数

  ISDATE() 函数用来确定输入表达式是否为有效日期。如果输入表达式是有效日期,那么 ISDATE 返回 1;否则,返回 0。

  ISDATE ( expression )

SELECT ISDATE(NULL) AS d1,
ISDATE('13/43/3425') AS d2,
ISDATE('1995-10-1a') AS d3,
ISDATE(19920808) AS d4,
ISDATE('1/23/95') AS d5,
ISDATE('1995-10-1') AS d6,
ISDATE('') AS d7,
ISDATE(' Abc') AS d8;

  8.ISNUMERIC() 函数

  ISNUMERIC(expression) 函数用来确定表达式是否为有效的数值类型。如果输入表达式的计算值为有效的整数、浮点数、money 或 decimal 类型时,ISNUMERIC 返回 1;否则返回 0。

SELECT ISNUMERIC(NULL) AS d1,
ISNUMERIC('13/43/3425') AS d2,
ISNUMERIC('30a.8') AS d3,
ISNUMERIC(19920808) AS d4,
ISNUMERIC('1/23/95') AS d5,
ISNUMERIC('3E-3') AS d6,
ISNUMERIC('') AS d7,
ISNUMERIC('-30.3') AS d8;

  9.辅助功能函数

  APP_NAME() 函数 返回当前会话的应用程序名称;
  CURRENT_USER 函数(注意这个函数不能带括号调用)返回当前登陆用户名;
  HOST_NAME() 函数 返回工作站名。

SELECT APP_NAME() AppName,
CURRENT_USER CurrentUser,
HOST_NAME() HostName,
NEWID() UUID;


【参考】《程序员的SQL金典》

[SQL] 函数整理(T-SQL 版)的更多相关文章

  1. Oracle常用SQL函数整理

    --返回ASCII码select  ASCII('A') "A的ASCII码" ,ASCII('a') "a的ASSCII码" from dual ; --反向 ...

  2. Java进阶SQL函数、网页定时刷新与自定义JSTL函数

    一.SQL函数 能够在SQL语句中调用的函数(方法) ,用来实现一些小功能 聚合函数 能够把多行数据聚合成一个值(统计) count()    计数,计算数据条数 max()      计算最大值 m ...

  3. mysql学习笔记—常用sql函数

    SQL 拥有很多可用于计数和计算的内建函数. SQL Aggregate 函数 SQL Aggregate 函数计算从列中取得的值,返回一个单一的值. 有用的 Aggregate 函数: AVG() ...

  4. 理解Spark SQL(三)—— Spark SQL程序举例

    上一篇说到,在Spark 2.x当中,实际上SQLContext和HiveContext是过时的,相反是采用SparkSession对象的sql函数来操作SQL语句的.使用这个函数执行SQL语句前需要 ...

  5. sql注入知识点整理(基础版)

    sql注入知识点整理(基础版) 基本步骤 判断是否报错 判断闭合符号 判断注入类型 构建payload 手工注入或者编写脚本 基本注入类型 报错型注入 floor公式(结果多出一个1):and (se ...

  6. 一个项目涉及到的50个Sql语句(整理版)

    /* 标题:一个项目涉及到的50个Sql语句(整理版) 说明:以下五十个语句都按照测试数据进行过测试,最好每次只单独运行一个语句. */ --1.学生表Student(S,Sname,Sage,Sse ...

  7. SQL函数说明大全

    一旦成功地从表中检索出数据,就需要进一步操纵这些数据,以获得有用或有意义的结果.这些要求包括:执行计算与数学运算.转换数据.解析数值.组合值和聚合一个范围内的值等. 下表给出了T-SQL函数的类别和描 ...

  8. oracle(sql)基础篇系列(一)——基础select语句、常用sql函数、组函数、分组函数

        花点时间整理下sql基础,温故而知新.文章的demo来自oracle自带的dept,emp,salgrade三张表.解锁scott用户,使用scott用户登录就可以看到自带的表. #使用ora ...

  9. SQL语句学习手册实例版

    SQL语句学习手册实例版 表操作 例1  对于表的教学管理数据库中的表 STUDENTS ,可以定义如下: CREATE  TABLE  STUDENTS (SNO      NUMERIC (6, ...

随机推荐

  1. 常见 Java 异常解释(恶搞版)

    常见 Java 异常解释:(译者注:非技术角度分析.阅读有风险,理解需谨慎o(╯□╰)o) java.lang ArithmeticException 你正在试图使用电脑解决一个自己解决不了的数学问题 ...

  2. BZOJ 1192: [HNOI2006]鬼谷子的钱袋(新生必做的水题)

    1192: [HNOI2006]鬼谷子的钱袋 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 3557  Solved: 2596[Submit][St ...

  3. B. Duff in Love

    B. Duff in Love time limit per test 2 seconds memory limit per test 256 megabytes input standard inp ...

  4. c++(线性队列)

    这里的线性结构实际上指的就是连续内存的意思,只不过使用“线性”这个词显得比较专业而已.前面一篇博客介绍了现象结构的处理方法,那么在这个基础之上我们是不是添加一些属性形成一种新的数据结构类型呢?答案是肯 ...

  5. Oracle复制表结构及数据

    1. 复制表结构及其数据:  create table table_name_new as select * from table_name_old 2. 只复制表结构:  ; 或者: create ...

  6. linux(CENTOS)系统各个目录的作用详解

    Linux(CentOS)系统各个目录的作用详解 文件的类型 LINUX有四种基本文件系统类型:普通文件.目录文件.连接文件和特殊文件,可用file命令来识别. 普通文件:如文本文件.C语言元代码.S ...

  7. windows下更改mysql数据储存物理目录

    windows10 1.停止mysql服务 以管理员身份运行cmd 输入命令 net stop mysql57 (我的mysql版本是5.7的,具体名称以你当前版本为主) 也可以打开任务管理器找到上面 ...

  8. 急!!ftp登录错误,提示 530 not logged in,连接失败 ,,是怎么回事啊

    愤怒地青鸟 | 浏览 68533 次 发布于2017-04-11 00:44 最佳答案 核心提示:Ftp登陆不了是很经常碰到的事,很多人常常是不加分析就发贴询问.老实说,这样既浪费自己时间,又浪费别人 ...

  9. jQuery时间格式插件-moment.js的使用

    jQuery时间格式插件-moment.js的使用 moment.js插件的使用,使用之前在页面引入对应的js文件: 详细的操作可见moment中文官网:http://momentjs.cn/ 日期格 ...

  10. NtDuplicateObject小解读

    源进程和目标进程可以是一个吗 当然执行进程可以是同一个吗 ,当然标志位重要!有一个关闭源进程的标志位 第一步通过ObReferenceHandleTable获得源进程对象(数据结构) //为新的句柄构 ...