首页 > 开发 > 综合 > 正文

TSQL基础(四)

2024-07-21 02:48:14
字体:
来源:转载
供稿:网友
TSQL基础(四) - 日期处理日期类型-DateTimeDateTime是sql中最常用的日期类型。

存储大小为:8个字节;

日期范围:1753-01-01到9999-12-31;

精确度:3.33毫秒;

常用的日期函数GetDate()获取系统当前日期
select GETDATE()
DatePart(part,dtValue) 获取日期中的一部分,part为要获取的部分,dtValue为日期

part 参数有:

日期部分 缩写year yy, yyyyquarter QQ, qmonth mm, mdayofyear dy, yday dd, dweek wk, wwweekday dwHour hhminute mi, nsecond ss, smillisecond ms

         select GETDATE() as '系统当前日期' ,                DATEPART(YEAR, GETDATE()) as '年',                DATEPART(month,GETDATE()) as '月',                DATEPART(DAY,GETDATE()) as '天',                DATEPART(HOUR,GETDATE()) as '小时',                DATEPART(minute,GETDATE()) as '分',                DATEPART(second,GETDATE()) as '秒',                DATEPART(Millisecond,GETDATE()) as '毫秒',                DATEPART(quarter,getdate()) as '季度',                 DATEPART(dayofyear,getdate()) as '从年初到现在的天数',                DATEPART(weekday,getdate()) as '今天是这个星期的第几天,从星期天开始',                DATEPART(week,getdate()) as '今年的第几周'                  --part简写          select GETDATE() as '系统当前日期' ,                DATEPART(YYYY, GETDATE()) as '年',                DATEPART(MM,GETDATE()) as '月',                DATEPART(DD,GETDATE()) as '天',                DATEPART(HH,GETDATE()) as '小时',                DATEPART(MI,GETDATE()) as '分',                DATEPART(SS,GETDATE()) as '秒',                DATEPART(MS,GETDATE()) as '毫秒',                DATEPART(qq,getdate()) as '季度' ,                DATEPART(dy,getdate()) as '从年初到现在的天数',                DATEPART(dw,getdate()) as '今天是这个星期的第几天,从星期天开始',                DATEPART(wk,getdate()) as '今年的第几周'
datename返回代表指定日期的指定日期部分的字符串
  SELECT datename(weekday, '2014-12-8')     SELECT datename(YY, '2014-12-8')   

year(dtValue),Month(dtValue),Day(dtValue)分别获取日期中:年,月,日的部分
 select year('2014-01-12'),        Month('2014-01-12'),        DAY('2014-01-12')                               
DateAdd(part,num,dtValue)对给定的某一日期加减,num为正数则为加,为负数则为减
select    '19901221' as  '给定的日期',        dateadd(year,2,'19901221') as '加2年' ,         dateadd(year,-2,'19901221') as '减2年',        dateadd(month,12,'19901221') as '加12个月',        dateadd(month,-12,'19901221') as '减12个月',         dateadd(day,31,'19901221') as '加31天',        dateadd(day,-31,'19901221') as '减31天' 

DateDiff(part,dtValue1.dtValue2)计算2个日期间的间隔
select  datediff(year,'1988-12-21','1990-12-21'),--大的时间在后面 间隔为正数                datediff(year,'1990-12-21','1988-12-21')--大的时间在前面面 间隔为负数    

日期格式convert(dataType,value[,style])函数可以将表达式由一种数据类型转换为另一种数据类型,而且可以把日期转换为新数据类型的通用函数
Style IDStyle 格式
100 或者 0mon dd yyyy hh:miAM (或者 PM)
101mm/dd/yy
102yy.mm.dd
103dd/mm/yy
104dd.mm.yy
105dd-mm-yy
106dd mon yy
107Mon dd, yy
108hh:mm:ss
109 或者 9mon dd yyyy hh:mi:ss:mmmAM(或者 PM)
110mm-dd-yy
111yy/mm/dd
112yymmdd
113 或者 13dd mon yyyy hh:mm:ss:mmm(24h)
114hh:mi:ss:mmm(24h)
120 或者 20yyyy-mm-dd hh:mi:ss(24h)
121 或者 21yyyy-mm-dd hh:mi:ss.mmm(24h)
126yyyy-mm-ddThh:mm:ss.mmm(没有空格)
130dd mon yyyy hh:mi:ss:mmmAM
131dd/mm/yy hh:mi:ss:mmmAM
  select GETDATE(),                    CONVERT(nvarchar(20),GETDATE(),120) as 'style=120',                    CONVERT(nvarchar(20),GETDATE(),101) as 'style=101',                    CONVERT(nvarchar(20),GETDATE(),112) as 'style=112'

顺便学习一下cast(exPRession as dataType[(length)])函数

cast()和convert()函数很相似,可以将表达式由一种数据类型转换为另一种数据类型,但无法像convert()函数一样设置时间格式

cast()是ANSI标准SQL,除非需要设置格式,否则优先选择cast()转换。

select  CAST('100' as  decimal(18, 2)) +11, --字符串转换为decimal                 convert(decimal(18, 2),'100')+11,--字符串转换为decimal                 '100'+11 --sql内部自动转换为int 

日期函数应用求本年第一天的日期
select DATEADD(YY,2,'2011')

dateadd年份相加时,月份天数时间都会为初始值。可以用这个特性来求出第一天日期。

1.选择一个日期为"中间值",算出今年和这个"中间值"相差多少年。

2.然后用"中间值"加上第一步中的求出相差的年份。

select DATEDIFF(yy,'2011',getdate()) --1.求出中间值2011和今年相差的年份为多少select DATEADD(yy,   DATEDIFF(yy,'2011',getdate()),   '2011')--2.然后用"中间值"加上第一步中的求出相差的年份。

"中间值"一般写0,写0时这个日期则为默认值'1900-01-01'

select DATEDIFF(yy,0,getdate())select DATEADD(yy,   DATEDIFF(yy,0,getdate()),  0)select DATEDIFF(yy,'1900-01-01',getdate())select DATEADD(yy,   DATEDIFF(yy,'1900-01-01',getdate()),   '1900-01-01')

那么就上一年或者明年第一天就只需要在相差的年份后面加减即可

select DATEADD(yy,   DATEDIFF(yy,0,getdate())-1,  0)--上一年开始一天select DATEADD(yy,   DATEDIFF(yy,0,getdate())+1,  0)--下一年开始一天select DATEADD(yy,   DATEDIFF(yy,0,'2008'),  0)--2008年开始一天

那么求本年第N天的日期只需要加(N-1)天数即可

select DATEADD(yy,   DATEDIFF(yy,0,getdate()),  0)+(101-1)--本年第101天的日期

那么求本月第一天的日期和第N天的日期,求本星期第一天和第N天的日期只需求改part部分即可

   --本月的第一天  select DATEADD(mm,   DATEDIFF(mm,0,getdate()),0)     --本月的第13天  select DATEADD(mm,   DATEDIFF(mm,0,getdate()),0)+(13-1)   --本星期的第一天  select DATEADD(WK,   DATEDIFF(WK,0,getdate()),0)     --本星期的第三天  select DATEADD(WK,   DATEDIFF(WK,0,getdate()),0)+(3-1)

求本年最后一天的日期

先求出下一年第一天的日期然后减去3毫秒即可

    select DATEADD(yy,   DATEDIFF(yy,0,getdate())+1,   0)--下一年第一天    SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate())+1,   0))  --得到下一年的开始一天 然后在减去3毫秒

为什么是减3毫秒?别的可以吗?

因为datetime类型的时间精度是3.33毫秒,如果超过该精度会进行近似到0.000,0.003,0.007 秒

    select DATEADD(ms,-1, '2015-01-01 00:00:00.000') as '减1毫秒',           DATEADD(ms,-2, '2015-01-01 00:00:00.000') as '减2毫秒',           DATEADD(ms,-3, '2015-01-01 00:00:00.000') as '减3毫秒',           DATEADD(ms,-4, '2015-01-01 00:00:00.000') as '减4毫秒',           DATEADD(ms,-5, '2015-01-01 00:00:00.000') as '减5毫秒'                  select DATEADD(ms,-6, '2015-01-01 00:00:00.000') as '减6毫秒',           DATEADD(ms,-7, '2015-01-01 00:00:00.000') as '减7毫秒',           DATEADD(ms,-8, '2015-01-01 00:00:00.000') as '减8毫秒',                          DATEADD(ms,-9, '2015-01-01 00:00:00.000') as '减9毫秒',           DATEADD(ms,-10, '2015-01-01 00:00:00.000') as '减10毫秒'    select                  DATEADD(ms,-11, '2015-01-01 00:00:00.000') as '减11毫秒',           DATEADD(ms,-12, '2015-01-01 00:00:00.000') as '减12毫秒',           DATEADD(ms,-13, '2015-01-01 00:00:00.000') as '减13毫秒',           DATEADD(ms,-14, '2015-01-01 00:00:00.000') as '减14毫秒',           DATEADD(ms,-15, '2015-01-01 00:00:00.000') as '减15毫秒'

那么就上一年或者明年第一天就只需要在相差的年份后面加减即可

SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0))  --上一年最后一天SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate())+2,   0))--下一年最后一天SELECT   dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,'2008')+1,   0))--2008年最后一天

那么求本月最后一天的日期,求本星期最后一天日期只需求改part部分即可

  SELECT   dateadd(ms,-3,DATEADD(mm,   DATEDIFF(mm,0,getdate())+1,  0))    --本月的最后一天       SE
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表