设为首页 收藏本站
查看: 618|回复: 0

[经验分享] SQL SERVER的时间函数

[复制链接]

尚未签到

发表于 2018-10-15 07:10:05 | 显示全部楼层 |阅读模式
  本文只讲SQL SERVER支持的时间函数,对于时间来说,有分:
  (1)日期:表示“年-月-日”信息的数据类型,其精度精确到“日”,其中包含了年、月、日三个信息,比如“2008-08-08”。而无时间点的概念。在数据库中,一般用Date来表示日期类型。
  (2)时间:表示“小时:分:秒” 信息的数据类型,其精度精确到“秒”,其中包含了小时、分、秒三个信息,比如“19:00:00”。而无日期的概念。在数据库中,一般用Time来表示时间类型。
  (3)日期时间:表示“年-月-日 小时:分:秒” 信息的数据类型,其精度精确到“秒”,其中包含了年、月、日、小时、分、秒六个信息,比如“2008-08-08 08:00:00”。既包含了日期,也包含了时间点。在数据库中,一般用DateTime来表示日期时间类型。
  (4)时间戳:表示比日期时间精度更高精度的时间类型。比如我们想区分表中两条记录插入表中的先后顺序,由于数据库操作速度非常快,如果用DateTime 类型记录输入插入时间的话,若两条记录插入的时间间隔非常短的话是无法区分它们的,这时就可以使用时间戳类型。数据库中,一般用TimeStamp来表示时间戳类型。
  不同的数据库系统对日期、时间、日期时间与时间戳等数据类型的支持差异性非常大,有的数据类型在有的数据库系统中不被支持,而有的数据类型在不同的数据库系统中表示精度和其类型名称所暗示的精度不同,比如Oracle 中的Date 类型中包含时间信息。数据库中的日期时间函数对这些类型的支持差别是非常小的,因此在一般情况下我们将这些类型统一称为“日期时间类型”。
  GETDATE()函数:获取得当前日期时间,返回的信息是包括了日期、时间(精确到秒以后部分)的时间戳信息。
SELECTGETDATE() as 当前日期时间  MSSQL Server 没有专门提供取得当前日期、取得当前时间的函数。但是通过间接的方式也可以获取到。主要是使用到Convert()函数。
  获取当前日期的方式:
SELECTCONVERT(VARCHAR(50) ,GETDATE( ), 101) as 当前日期  获取当前日期的方式:
SELECTCONVERT(VARCHAR(50) ,GETDATE(), 108) as 当前时间  DATEADD (datepart , number, date )函数:用于进行日期时间的加法运算,其中datepart参数是表示日期部分的参数(比如是以日期还是以月份相加等),number参数是具体的加数,正数代表向未来日期方向加,负数代表向过去日期方向减,date参数为待计算的日期时间类型数据。
SELECTDATEADD(MONTH, 1, GETDATE())SELECT FBirthDay, DATEADD (YEAR ,3,FBirthDay) as threeyrs,DATEADD(QUARTER ,20,FBirthDay) as ttqutrs,DATEADD(MONTH ,68,FBirthDay) as sxtmonths,DATEADD(WEEK, -1000,FBirthDay) as thweeikFROM T_Person  datepart参数可以取的单位类型如下:
单位别名说明yearyy,yyyy年份quarterqq,q季度monthmm,m月份dayofyeardy,y当年度的第几天daydd,d日weekwk,ww当年度的第几周weekdaydw,w星期几hourhh小时minutemi,n分secondss,s秒millisecondms毫秒  DATEDIFF ( datepart , startdate , enddate )函数:用于计算两个日期时间之间的差额。其中datepart参数表示日期部分的参数(比如只比较年还是只比较月等),startdate参数为起始日期时间类型数据;enddate参数为结束日期时间类型数据。
SELECTDATEDIFF(DAY, '2013/12/17 21:00:00', '2013/12/19 10:00:00')SELECT FRegDay,FBirthDay,DATEDIFF(WEEK, FBirthDay, FRegDay) FROM T_Person  datepart参数可以取的单位类型如下:
单位别名说明yearyy, yyyy年quarterqq, q季度monthmm, m月dayofyear dy, y工作日daydd, d天数weekwk, ww周Hourhh小时minutemi, n分钟secondss, s秒millisecondms毫秒  DATENAME(datepart,date)函数:用来获取一个日期的特定部分,比方只获取年份或者是只获取月份等。其中datepart参数是表示要返回的日期部分的参数(即如果是Year的话,则返回的是具体的年份),date参数为待计算日期。
SELECT FBirthDay,DATENAME(Weekday,FBirthDay),FRegDay,DATENAME(DW, FRegDay)FROM T_Person  datepart参数可以取的单位类型如下:
单位别名说明Yearyy、yyyy年份Quarterqq, q季度Monthmm, m月份Dayofyeardy, y每年的某一日Daydd, d日期Weekwk, ww星期Weekdaydw工作日Hourhh小时Minute mi, n 分钟Second ss, s 秒Millisecond ms 毫秒  DATEPART (datepart,date)函数:MSSQL SERVER提供另一个函数也同样可以实现获取日期时间特定部分。其中datepart参数是表示要返回的日期部分的参数(即如果是Year的话,则返回的是具体的年),date参数为待计算日期。
SELECT FBirthDay, DATEPART(Dayofyear,FBirthDay),FRegDay, DATEPART(Year, FRegDay)FROM T_Person  datepart参数可以取的单位类型如下:
单位别名说明Yearyy、yyyy年份Quarterqq, q季度Monthmm, m月份Dayofyeardy, y每年的某一日Daydd, d日期Weekwk, ww星期Weekdaydw工作日Hourhh小时Minute mi, n 分钟Second ss, s 秒Millisecond ms 毫秒  注:DATEPART()函数的返回值是数字,而DATENAME()函数则会将尽可能以名称的方式做为返回值。



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-621649-1-1.html 上篇帖子: SQL Server 笔记整理 下篇帖子: 查看SQL Server对象的定义语句
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表