SQLServer中的常用函数
字符串函数
len() 计算字符串的长度
1 | select LEN(name) from test1
|
大小写转换 lower() upper()
1 2 | select lower('STUDENT !')
select upper('student !')
|
去空 ltrim() 字符串左侧的空格去掉 ,rtrim()字符串右侧的空格去掉
1 2 3 | declare @str varchar(100) = ' a a a '
select ltrim(@str)
select rtrim(@str)
|
字符串截取 substring() left() right()
1 2 3 | select substring('HelloWorld!',6,6)
select left('HelloWorld!' ,5)
select right('HelloWorld!' ,6)
|
字符串替换 replace()
1 | select replace('HelloWorld!','o','e')
|
字符串 掉个顺序 reverse()
返回 字符串1在字符串2中出现的未位置 charindex()
1 2 3 | charindex(srt1 ,srt2)
select charindex('H','elloHWorld') 结果为:5
|
指定的次数重复字符串值 replicate()
1 | select replicate('abc',4) 结果为:abcabcabcabc
|
聚合函数
聚合函数对一组值计算后返回单个值。除了count(统计项数)函数以外,其他的聚合函数在计算式都会忽略空值(null)。所有的聚合函数均为确定性函数。
平均值 avg() 算一组数的总和,然后除以为null的个数,得到平均值。
1 | select avg(id) from test1 avg(列名)
|
最小值min() 最大值max()
1 2 | select min(id) from test1
select max(id) from test1
|
求和 sum()
1 | select sum(id) from test1
|
计算总数 count()
1 | select count(id) from test1
|
分组
1 2 3 4 | 统计学生的总成绩并排序
select stu_id as 学生编号 ,name as 学生姓名 , SUM(语文+英语+数学+代数) as 总分from tb_stuAchievement
ORDER BY 总分 DESC
GROUP BY stu_id ,name
|
(函数可能不全,我只记录了我用到的,完整的函数可以查查手册)
日期和时间函数
获取当前日期GetDate
GetUTCDate 获取UTC时间值
单独获取年月日
1 2 3 | select year(getdate())
select month(getdate())
select day(getdate())
|
日期减法 DATEDIFF
1 2 | select datediff(YYYY,'2011-11-11','2012-12-12')
select datediff(day,'2011-11-11','2012-12-12')
|
SQLServer 2008中新增的日期时间型函数
1 2 3 4 5 6 7 | 1、获取系统时间 SysDateTime()
2、获取当前日期和时间 SysDateTimeOffset
3、获取系统UTC时间 SysUTCDateTime
4、Current_TimeStamp当前数据库系统时间戳
5、判断是否为日期数据isDate
select isdate('2012-12-12') -- 输出1
select isdate('xxxx-12-12') -- 输出0
|
(函数可能不全,我只记录了部分,完整的函数可以查查手册)
MID() 从文本字段中提取字符。
1 | select MID(City,1,3) as SmallCity FROM Persons
|
ROUND() 函数 数值字段舍入为指定的小数位数。
1 | select ROUND(column_name,decimals) FROM table_name
|
NOW() 函数 返回当前的日期和时间。
1 | select NOW() FROM table_name
|
FORMAT () 用于对字段的显示进行格式化。
1 | select FORMAT(stu_intime,'yyyy-MM-dd hh:mm:ss') as intime from stu
|
select INTO 从一个表中选取数据,然后把数据插入另一个表中。
1 | select stu_name,stu_id into stu1 from stu
|
sql server 中没有limit 但是有top
1 2 3 4 5 6 7 8 9 10 11 | /*查询 从n开始的m条数据 */
declare @n int=2;
declare @m int = 5;
select top (@m) * from stu
where id not in (select top (@n) id from stu)
/*查询n到m之间的数据*/
declare @n int=2;
declare @m int = 5;
select top (@m-@n+1) * from stu
where id not in (select top (@n-1) id from stu)
|
BETWEEN … AND 会选取介于两个值之间的数据范围。这些值可以是数值、文本或者日期。
1 2 | /* 查询id 1 到3 的数据 */
select * from stu where id between '1' and '3'
|
ALTER TABLE 语句用于在已有的表中添加、修改或删除列。
1 2 3 | alter table stu add stu_sj varchar(200)
alter table stu drop column stu_sj
|
DISTINCT 用于返回唯一不同的值。
1 2 | /* 返回名字,重复的不返回 */
select distinct stu_name from stu
|