1、cast
cast(data as Data_Type)
例:declare @data int
set @data=5
select cast(@data as char(2))+'ABC'
-- 结果为: 5 ABC
2、convert
convert(data_Type,expresses(,style)) -- style 为指定日期的样式
3、datediff
datediff(datepart,startdate,enddate)
参数:datepart 列表
日期部分 | 缩写 |
---|---|
year | yy, yyyy |
quarter | qq, q |
Month | mm, m |
dayofyear | dy, y |
Day | dd, d |
Week | wk, ww |
Hour | hh |
minute | mi, n |
second | ss, s |
millisecond | ms |
4、 dateadd(datepart,number,date)
查看系统设置的每周的第一天 -- select @@datefirst
datediff 与 dateadd 综合使用实例:
-- 查询当月的第一天
select dateadd(mm,datediff(mm,0,getdate()),0)
-- 查询本周的星期一
Select DATEADD(wk, DATEDIFF(wk,0,getdate()),0)
-- 查询一年的第一天
Select DATEADD(yy, DATEDIFF(yy,0,getdate()),0)
-- 查询一个季度的第一天
Select DATEADD(qq, DATEDIFF(qq,0,getdate()),0)
-- 查询上个月的最后一天(相当于本月第一天减去1天)
Select dateadd(day,-1,DATEADD(mm, DATEDIFF(mm,0,getdate()), 0))
-- 查询去年的最后一天
Select dateadd(day,-1,DATEADD(yy, DATEDIFF(yy,0,getdate()),0) )
-- 查询本月的最后一天
Select dateadd(day,-1,DATEADD(mm, DATEDIFF(mm,0,getdate())+1, 0))
-- 查询本年的最后一天
Select dateadd(day,-1,DATEADD(yy, DATEDIFF(yy,0,getdate())+1,0))
-- 查询本月的第一个星期一
这里需要用到另外一个函数
datepart(datepart,date) -- 返回指定日期的指定类型的整数部分
select DATEADD(wk, DATEDIFF(wk,0,dateadd(dd,6-datepart(day,getdate()),getdate())), 0)