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

sqlserver日期函数

发布时间:2020-12-12 14:05:03 所属栏目:MsSql教程 来源:网络整理
导读:SQLServer时间日期函数详解,SQLServer,时间日期, 1.????? 当前系统日期、时间 ??????? select getdate()? 2. dateadd????? 在向指定日期加上一段时间的基础上,返回新的 datetime 值 ?????? 例如: ?????? 1.向日期加上2天 ?????? select dateadd(day,2,''20

SQLServer时间日期函数详解,SQLServer,时间日期,
1.????? 当前系统日期、时间
??????? select getdate()?


2. dateadd????? 在向指定日期加上一段时间的基础上,返回新的 datetime 值
?????? 例如:

?????? 1.向日期加上2天
?????? select dateadd(day,2,''2004-10-15'')????? --返回:2004-10-17 00:00:00.000

??????? 2.向月份加上2天

?????? select dateadd(month,''2004-10-15'')??? --返回:2004-12-17 00:00:00.000


3. datediff 返回跨两个指定日期的日期和时间边界数
?????? select datediff(day,''2004-09-01'',''2004-09-18'')?????? --返回:17
?????? select datediff(day,''2004-09-18'',''2004-09-01'')?????? --返回:-17

?????? 比较两个datetime 类型数据A、B是否同年同月同日的方法

?????? where datediff(day,A,B) = 0

?????? 同样,要比较A、B是否同年同月的方法是
?????? where datediff(month,B) = 0

4. datepart 返回代表指定日期的指定日期部分的整数
????? SELECT DATEPART(month,''2004-10-15'')????? --返回 10


5. datename 返回代表指定日期的指定日期部分的字符串
?????? SELECT datename(weekday,''2004-10-15'')????? --返回:星期五

?????? SELECT datename(weekday,getdate())????? --返回:当前星期


6. day(),month(),year() --可以与datepart对照一下
select 当前日期=convert(varchar(10),getdate(),120)
,当前时间=convert(varchar(8),114)
select datename(dw,''2004-10-15'')
select 本年第多少周=datename(week,''2004-10-15'')
?????????,今天是周几=datename(weekday,''2004-10-15'')

返回当前日期,当前时间,今天周几,本年第几周

select convert(varchar(10),convert(varchar(8),114),datename(dw,getdate()),datename(week,getdate())

?


函数 参数/功能
GetDate( )?? 返回系统目前的日期与时间
DateDiff (interval,date1,date2) 以interval 指定的方式,返回date2 与date1两个日期之间的差值 date2-date1
DateAdd (interval,number,date) 以interval指定的方式,加上number之后的日期
DatePart (interval,date) 返回日期date中,interval指定部分所对应的整数值
DateName (interval,date) 返回日期date中,interval指定部分所对应的字符串名称
参数 interval的设定值如下:
值 缩 写(Sql Server) (Access 和 ASP) 说明
Year Yy yyyy 年 1753 ~ 9999
Quarter Qq q??? 季 1 ~ 4
Month Mm m??? 月1 ~ 12
Day of year Dy y?? 一年的日数,一年中的第几日 1-366
Day Dd d??? 日,1-31
Weekday Dw w 一周的日数,一周中的第几日 1-7
Week Wk ww?? 周,一年中的第几周 0 ~ 51
Hour Hh h??? 时0 ~ 23
Minute Mi n?? 分钟0 ~ 59
Second Ss s 秒 0 ~ 59
Millisecond Ms - 毫秒 0 ~ 999
access 和 asp 中用date()和now()取得系统日期时间;其中DateDiff,DateAdd,DatePart也同是能用于Access和asp中,这些函数的用法也类似
举例:
1.GetDate() 用于sql server :select GetDate()
2.DateDiff(''s'',''2005-07-20'',''2005-7-25 22:56:32'')返回值为 514592 秒
DateDiff(''d'',''2005-7-25 22:56:32'')返回值为 5 天
3.DatePart(''w'',''2005-7-25 22:56:32'')返回值为 2 即星期一(周日为1,周六为7)
DatePart(''d'',''2005-7-25 22:56:32'')返回值为 25即25号
DatePart(''y'',''2005-7-25 22:56:32'')返回值为 206即这一年中第206天
DatePart(''yyyy'',''2005-7-25 22:56:32'')返回值为 2005即2005年

具体的语法:
日期函数用来操作DATETIME 和SMALLDATETIME 类型的数据,执行算术运算。与其它函数一样,可以在Select 语句的Select 和Where 子句以及表达式中使用日期函数。其使用方法如下:
日期函数参数,其中参数个数应不同的函数而不同。
·DAY()
DAY() 函数语法如下:
DAY (<date_expression>)
DAY() 函数返回date_expression 中的日期值。
·MONTH()
MONTH() 函数语法如下:
MONTH (<date_expression>)
MONTH() 函数返回date_expression 中的月份值。
与DAY() 函数不同的是,MONTH() 函数的参数为整数时,一律返回整数值1,即SQL Server 认为其是1900 年1 月。
·YEAR()
YEAR() 函数语法如下:
YEAR (<date_expression>)
YEAR() 函数返回date_expression 中的年份值。
提醒:在使用日期函数时,其日期值应在1753年到9999年之间,这是SQL Server系统所能识别的日期范围,否则会出现错误
·DATEADD()
DATEADD() 函数语法如下:
DATEADD (<datepart>, <number>, <date>)
DATEADD() 函数返回指定日期date 加上指定的额外日期间隔number 产生的新日期。参数“datepart” 在日期函数中经常被使用,它用来指定构成日期类型数据的各组件,如年、季、月、日、星期等:
·DATEDIFF()
DATEDIFF() 函数语法如下:
DATEDIFF() (<datepart>, <date1>, <date2>)
DATEDIFF() 函数返回两个指定日期在datepart 方面的不同之处,即date2 超过date1的差距值,其结果值是一个带有正负号的整数值。针对不同的datepart, DATEDIFF()函数所允许的最大差距值不一样,如:datepart 为second 时,DATEDIFF() 函数所允许的最大差距值为68: 年datepart 为millisecond 时,DATEDIFF() 函数所允许的最大差距值为24 天20 小时30 分23 秒647 毫秒。
·DATENAME()
DATENAME() 函数语法如下:
DATENAME (<datepart>, <date)>
DATENAME() 函数以字符串的形式返回日期的指定部分此部分。由datepart 来指定。
·DATEPART()
DATEPART() 函数语法如下:
DATEPART (<datepart>, <date>)
DATEPART() 函数以整数值的形式返回日期的指定部分。此部分由datepart 来指定。
DATEPART (dd, date) 等同于DAY (date)
DATEPART (mm, date) 等同于MONTH (date)
DATEPART (yy, date) 等同于YEAR (date)
·GETDATE()
GETDATE() 函数语法如下:
GETDATE()
GETDATE() 函数以DATETIME 的缺省格式返回系统当前的日期和时间,
在开发数据库应用中,经常会遇到处理时间的问题,如查询指定时间的记录等。下面就这些常见的问题,结合自己的一些经验,和大家探讨一下这类问题。
  首先介绍一下,SQL Server里处理时间的几个主要函数的用法:
getdate()函数:取得系统当前的日期和时间。返回值为datetime类型的。
用法:getdate()
例子:
select getdate() as dte,dateadd(day,-1,getdate()) as nowdat
输出结果:
dte nowdat
1999-11-21 19:13:10.083 1999-11-20 19:13:10.083
(1 row(s) affected)


datepart()函数:以整数的形式返回时间的指定部分。
用法:datepart(datepart,date)
参数说明:datepart时要返回的时间的部分,常用取值year、month、day、hour、minute。
date是所指定的时间。
例子:
SELECT DATEPART(month,GETDATE()) AS ''Month Number''
输出结果:
Month Number
11
(1 row(s) affected)


dateadd()函数:通过给指定的时间的指定部分加上一个整数值以返回一个新时间值。
用法:dateadd(datepart,date)
参数说明:datepart(同上)
date(同上)
number要增加的值,整型,可正可负,正值返回date之后的时间值,负值返回date
之前的时间值
例子:
select getdate() as today
select dateadd(day,getdate())
select dateadd(day,1,getdate())
输出:
today
1999-11-21 19:42:41.410
(1 row(s) affected)
yesterday
1999-11-20 19:42:41.410
(1 row(s) affected)
tomorrow
1999-11-22 19:42:41.410
(1 row(s) affected)


datediff()函数:返回两个时间以指定时间部分来计算的差值。返回整数值。如1991-6-12和1991-6-21之间以天
来算相差9天,1998-6-12和1999-6-23按年算相差1年,1999-12-1和1999-3-12按月算相差9个月
用法:datediff(darepart,date2)
参数说明:datepart(同上)
date1、date2(同上date)
例子:
select datediff(month,''1991-6-12'',''1992-6-21'') as a
输出:
a

12
(1 row(s) affected)?
?
?

1.一个月第一天的
SELECT DATEADD(mm,DATEDIFF(mm,0)

2.本周的星期一
SELECT DATEADD(wk,DATEDIFF(wk,0)

3.一年的第一天
SELECT DATEADD(yy,DATEDIFF(yy,0)

4.季度的第一天
SELECT DATEADD(qq,DATEDIFF(qq,0)

5.当天的半夜
SELECT DATEADD(dd,DATEDIFF(dd,0)

6.上个月的最后一天
SELECT dateadd(ms,-3,DATEADD(mm,0))

7.去年的最后一天
SELECT dateadd(ms,DATEADD(yy,0))

8.本月的最后一天
SELECT dateadd(ms,DATEDIFF(m,getdate())+1,0))

9.本年的最后一天
SELECT dateadd(ms,0))

10.本月的第一个星期一
select DATEADD(wk,dateadd(dd,6-datepart(day,getdate())),0)

1.用一条语句得出某日期所在月份的最大天数?

SELECT DAY(DATEADD(dd,-DAY('2004-02-13'),'2004-02-13'))) AS 'Day Number'

?

查询最近一天,三天,一周,一月,一季度方法:

一天?"select * from T_news where datediff(day,addtime,getdate())=0";

?

三天?"select * from T_news where datediff(day,getdate())<= 2 and datediff(day,getdate())>= 0";

一周?"SELECT * FROM T_news WHERE (DATEPART(wk,addtime) = DATEPART(wk,GETDATE())) AND (DATEPART(yy,addtime) = DATEPART(yy,GETDATE()))";

一月"SELECT * FROM T_news WHERE (DATEPART(yy,GETDATE())) AND (DATEPART(mm,addtime) = DATEPART(mm,GETDATE()))";

一季度?"select * from T_news where DATEPART(qq,addtime) = DATEPART(qq,GETDATE()) and DATEPART(yy,GETDATE())";

(编辑:李大同)

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

    推荐文章
      热点阅读