T-SQL 时刻操纵(dateadd ,datediff ,datepart ,datename )
发布时间:2021-01-12 19:15:45 所属栏目:编程 来源:网络整理
导读:本日PHP站长网 52php.cn把网络自互联网的代码分享给各人,仅供参考。 --1. 当前体系日期、时刻 select getdate() --2015-01-06 09:27:27.277 --2.时刻操纵 dateadd 在向指定日期加上一段时刻的基本上,返回新的 datetime
|
以下代码由PHP站长网 52php.cn网络自互联网 此刻PHP站长网小编把它分享给各人,仅供参考 --1. 当前体系日期、时刻
select getdate() --2015-01-06 09:27:27.277
--2.时刻操纵 dateadd 在向指定日期加上一段时刻的基本上,返回新的 datetime 值
dateadd(datepart,number,date)
注:
datepart : year(yy,yyyy) | quarter(qq,q) | month(mm,m) | week(ww,wk) | day(dd,dy) | hour(h) | minute(mi,n) |
second (ss,s)| millisecond(ms)
date 参数是正当的日期表达式。number 是您但愿添加的隔断数;对付将来的时刻,此数是正数,对付已往的时刻,此数是负数。
例:
select getdate()
select dateadd(year,1,getdate()) --2016-01-06 09:27:27.277
select dateadd(month,getdate()) --2017-02-06 09:27:27.277
select dateadd(day,getdate()) --2015-01-07 09:27:27.277
select dateadd(week,getdate()) --2015-01-13 09:27:27.277
select dateadd(weekday,getdate()) --2015-01-07 09:27:27.277
select dateadd(hour,getdate()) --2015-01-06 10:27:27.277
select dateadd(Minute,getdate()) --2015-01-06 09:28:27.277
select dateadd(Second,getdate()) --2015-01-06 09:28:28.277
--3. datediff 返回跨两个指定日期的日期和时刻界线数。
datediff( date-part,startdate,enddate )
注:
datepart : year(yy,s)| millisecond(ms)
startdate 和 enddate 参数是正当的日期表达式。
返回值:(enddate)-(startdate)
例:
select datediff(year,getdate(),dateadd(year,2,getdate())) --返回:2
SELECT * FROM crm_contract where datediff(month,Subtime,getdate())=0 --查察crm_contract申请时刻subtime是本月的数据
--4. datepart 函数用于返回日期/时刻的单独部门,好近年、月、日、小时、分钟等等。
--假如必要获得本身必要的日期,则必要讲日期时刻名目化
SELECT DATEPART(year,getdate()) as '年份'
SELECT DATEPART(month,getdate()) as '月份'
SELECT DATEPART(day,getdate()) as '日期'
SELECT DATEPART(week,getdate()) as '今年第几周数'
SELECT (DATEPART(weekday,getdate())-1) as '本日是周几?'
SELECT DATEPART(hour,getdate()) as '小时'
SELECT DATEPART(Minute,getdate()) as '分钟'
SELECT DATEPART(Second,getdate()) as '秒时'
--5. datename 返回代表指定日期的指定日期部门的字符串
SELECT datename(weekday,getdate()) as '本日是礼拜几?'
SELECT datename(month,convert(varchar(10),126)) as '本日是几月份?'
SELECT datename(day,126)) as '本日是几号?'
SELECT datename(year,126)) as '本年是哪年?'
--上周周一
SELECT DATEADD(wk,DATEDIFF(wk,getdate()),-7)
--上周周天
SELECT DATEADD(wk,-1)
--.本周周一
SELECT DATEADD(wk,0)
--.本周周天
select dateadd(wk,datediff(wk,6)
--下周周一
select dateadd(wk,7)
--下周周天
select dateadd(wk,13)
--1.本月第一天
SELECT DATEADD(mm,DATEDIFF(mm,0)
--.本月最后一天
SELECT dateadd(ms,-3,DATEADD(mm,DATEDIFF(m,getdate())+1,0))
--.本周礼拜一
SELECT DATEADD(wk,0)
--.本周礼拜天
select dateadd(wk,6)
--.今年第一天
SELECT DATEADD(yy,DATEDIFF(yy,0)
--.今年最后一天
SELECT dateadd(ms,DATEADD(yy,0))
--.本季度第一天
SELECT DATEADD(qq,DATEDIFF(qq,0)
--.当天的三更
SELECT DATEADD(dd,DATEDIFF(dd,0)
--.上个月的最后一天
SELECT dateadd(ms,0))
--.客岁的最后一天
SELECT dateadd(ms,0))
--.本月的第一个礼拜一
select DATEADD(wk,dateadd(dd,6-datepart(day,getdate())),0)
以上内容由PHP站长网【52php.cn】网络清算供各人参考研究 假如以上内容对您有辅佐,接待保藏、点赞、保举、分享。 (编辑:湖南网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |


