加入收藏 | 设为首页 | 会员中心 | 我要投稿 东莞站长网 (https://www.0769zz.com/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > MySql教程 > 正文

T-SQL 时间操作(dateadd ,datediff ,datepart ,datename )

发布时间:2021-01-12 15:23:45 所属栏目:MySql教程 来源:网络整理
导读:今天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】收集整理供大家参考研究

如果以上内容对您有帮助,欢迎收藏、点赞、推荐、分享。

(编辑:东莞站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读