博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
DateADD日期Sql
阅读量:4563 次
发布时间:2019-06-08

本文共 3190 字,大约阅读时间需要 10 分钟。

--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
,1,getdate())  
--2017-02-06 09:27:27.277 
    
select
dateadd(
day
,1,getdate())    
--2015-01-07 09:27:27.277
    
select
dateadd(week,1,getdate())   
--2015-01-13 09:27:27.277
    
select
dateadd(weekday,1,getdate())
--2015-01-07 09:27:27.277
    
select
dateadd(
hour
,1,getdate())   
--2015-01-06 10:27:27.277
    
select
dateadd(
Minute
,1,getdate()) 
--2015-01-06 09:28:27.277
    
select
dateadd(
Second
,1,getdate()) 
--2015-01-06 09:28:28.277
 
--3. datediff 返回跨两个指定日期的日期和时间边界数。
datediff(
date
-part, startdate, enddate )
注:
    
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)
    
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), getdate(),126))
as
'今天是几月份?'
SELECT
datename(
day
,
convert
(
varchar
(10), getdate(),126))  
as
'今天是几号?'
SELECT
datename(
year
,
convert
(
varchar
(10), getdate(),126))  
as
'今年是哪年?'
 
--上周周一
SELECT  
DATEADD(wk,   DATEDIFF(wk,0,getdate()),-7)
--上周周天
SELECT  
DATEADD(wk,   DATEDIFF(wk,0,getdate()),-1)
--.本周周一
SELECT  
DATEADD(wk,   DATEDIFF(wk,0,getdate()),0)
--.本周周天 
select  
dateadd(wk,datediff(wk,0,getdate()),6)
--下周周一
select  
dateadd(wk,datediff(wk,0,getdate()),7)
--下周周天
select  
dateadd(wk,datediff(wk,0,getdate()),13)
--1.本月第一天  
SELECT  
DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0)  
   
--.本月最后一天  
SELECT  
dateadd(ms,-3,DATEADD(mm,   DATEDIFF(m,0,getdate())+1,   0))     
--.本周星期一  
SELECT  
DATEADD(wk,   DATEDIFF(wk,0,getdate()),   0) 
  
--.本周星期天   
select  
dateadd(wk,datediff(wk,0,getdate()),6) 
  
--.本年第一天  
SELECT  
DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0)  
  
--.本年最后一天  
SELECT  
dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate())+1,   0))    
--.本季度第一天  
SELECT  
DATEADD(qq,   DATEDIFF(qq,0,getdate()),   0)  
      
--.当天的半夜  
SELECT  
DATEADD(dd,   DATEDIFF(dd,0,getdate()),   0)  
      
--.上个月的最后一天  
SELECT  
dateadd(ms,-3,DATEADD(mm,   DATEDIFF(mm,0,getdate()),   0))  
      
--.去年的最后一天  
SELECT  
dateadd(ms,-3,DATEADD(yy,   DATEDIFF(yy,0,getdate()),   0))  
      
  
--.本月的第一个星期一  
select  
DATEADD(wk,  
DATEDIFF(wk,0,dateadd(dd,6-datepart(
day
,getdate()),getdate())),   0)

转载于:https://www.cnblogs.com/Li-yuan/p/6180391.html

你可能感兴趣的文章
Centos7,PHP7安装swoole
查看>>
02_ListActive中响应事件 并LogCat输出
查看>>
doubleclick adx note
查看>>
Celery框架
查看>>
[c#]asp.net开发微信公众平台(4)关注事件、用户记录、回复文本消息
查看>>
[转载,感觉写的非常详细]DUBBO配置方式详解
查看>>
linux Valgrind使用说明-内存泄漏
查看>>
Android在Eclipse上的环境配置
查看>>
面向对象(五)
查看>>
android平台下使用点九PNG技术
查看>>
Python学习3,列表
查看>>
最长回文子串
查看>>
JAVA基础-JDBC(一)
查看>>
js中for和while运行速度比较
查看>>
简单理解什么是递归(阶乘演示)
查看>>
http协议
查看>>
js倒计时,页面刷新时,不会从头计时
查看>>
洛谷1156垃圾陷阱
查看>>
python ==》 递归
查看>>
简单网络请求封装
查看>>