T-SQL作为SQL的扩展语言,是SQL程序设计语言的增强版,它是用来让应用程序与SQL Server沟通的主要语言。T-SQL提供标准SQL的DDL和DML功能,加上延伸的函数、系统预存程序以及程式设计结构(如IF和WHILE)让程续设计更有弹性。
说一下T-SQL的由来。美国国家标准局(ANSI)与国际标准化组织已经制定了SQL标准,美国国家标准局发布与国际标准化组织相应的美国标准(可以理解为方便本国使用),1992年国际标准化组织和International Electrotechnical Commission(IEC)发布了SQL国际标准,称为SQL-92。美国国家标准局随之发布的相应标准是ANSI SQL-92。尽管不同的数据库使用的SQL版本有一些差异,但大多数都遵循ANSI SQL标准。SQL Server使用ANSI SQL-92的扩展集,称为T-SQL。
如果用一句话概括的话,SQL作为结构化查询语言,是标准的关系型数据库通用的标准语言;T-SQL是在SQL基础上扩展的SQL Server中使用的语言。
T-SQL里的函数可以理解为
是一个可反复使用的程序段(脚本)
是从其他的程序段中使用调用语句来执行这段程序
也就是提前写好一段语句,取一个名字,使用时调用这个名字
函数又分为很多种,说一下常用的函数及用法
系统函数:转换数据类型,以及查看系统参数
Ø Convert():数据类型转换为字符串
select converet(varchar(5),12345)
12345 数字 ‘12345’字符串
Ø CAST():转换数据类型(简单)
select cast (’2019-01-18’ as datetime) //将字符串转换成时间类
2019-01-18 00:00:00
Ø Current_User():查看当前登入数据库用户名
select current_user
Ø System_User():查看当前用户名
select system_user
字符串函数
CharIndex( )
用来寻找一个指定的字符串在另一个字符串中的起始位置
SELECT
CHARINDEX(‘BDQN’,‘www.bdqn.cn’,1)
返回:5
Len( )
返回传递给它的字符串长度
SELECT LEN(‘SQL Server课程’)
返回:12
Upper( )
把传递给它的字符串转换为大写
SELECT UPPER(‘SQL Server课程’)
返回:SQL SERVER课程
Ltrim( )
清除字符左边的空格
SELECT LTRIM (’ BDQN
')
返回:BDQN (后面的空格保留)
Rtrim( )
清除字符右边的空格
SELECT RTRIM(’ BDQN
')
返回: BDQN前面的空格保留)
Right( )
从字符串右边返回指定数目的字符
SELECT RIGHT(‘ABCDEFG’,3)
返回:EFG
Replace( )
替换一个字符串中的字符
SELECT REPLACE(‘ABABAB’,‘B’,‘A’)
返回:AAAAAA
Stuff( )
在一个字符串中,删除指定位置指定长度的字符串,并在该位置插入一个新的字符串
SELECT STUFF(‘ABCDEFG’,2,3,
‘我的音乐我的世界’)
返回:A我的音乐我的世界EFG
日期函数:
select
dateadd(dd,3000,GETDATE())
当前天数增加3000天 ‘dd天 mm月 yy年’
select
datediff(dd,’1998-06-13’,getdate())
求两个日期某段的差
select
datename(DW,’1998-06-13’)
求日期的星期数
select
姓名,datediff(yy,出生日期,getdate())AS 年龄
from CSDN
//查看员工年龄(周岁)
聚合函数
SUM():求和
AVG():求平均值
MAX():求最大值
MIN():最小值
select SUM(基本工资) AS 总工资 from CSDN
select AVG(基本工资) AS 平均工资,MAX(基本工资)AS最大,MIN(基本工资)AS最小 from CSDN
数学函数
Abs( )
取数值表达式的绝对值
SELECT ABS(-43)
返回:43
Ceiling( )
取大于或等于指定数值、表达式的最小整数
SELECT CEILING(43.5)
返回:44
Floor( )
取小于或等于指定表达式的最大整数
SELECT FLOOR(43.5)
返回:43
Power( )
取数值表达式的幂值
SELECT POWER(5,2)
返回:25
Round( )
将数值表达式四舍五入为指定 精度
SELECT ROUND(43.543,1)
返回:43.500
Sign( )
对于正数返回+1,对于负数返回-1,对于0则返回0
SELECT SIGN(-43)
返回:-1
Sqrt( )
取浮点表达式的平方根
SELECT SQRT(10.89)
返回:3.3