SqlServer获取当前日期

  1. 获取当前日期
select GETDATE()

格式化 --2022-12-14 13:42:14 或 20221214

select CONVERT(varchar,GETDATE(),120)--2022-12-14 13:42:14
select CONVERT(varchar,GETDATE(),112)--20221214
  1. 获取当前年 --2022
select DATENAME(YYYY,GETDATE()) --2022

select DATENAME(YEAR,GETDATE()) --2022

select DATEPART(YYYY,GETDATE()) --2022

select DATEPART(YEAR,GETDATE()) --2022

select YEAR(GETDATE())--2022

  1. 获取当前月 --05或5
select DATENAME(MM,GETDATE()) --04

select DATENAME(MONTH,GETDATE()) --04

 

select DATEPART(MM,GETDATE()) --4

select DATEPART(MONTH,GETDATE()) --4

 

select MONTH(时间字段名) --4
  1. 获取当前日期 --07或7
select DATENAME(DAY,GETDATE()) --23
select DATENAME(D,GETDATE()) --23
select DATENAME(DD,GETDATE()) --23

 

select DATEPART(D,GETDATE()) --23
select DATEPART(DD,GETDATE()) --23 
select DATEPART(DAY,GETDATE()) --23

 

select DAY(GETDATE())
  1. 获取当前年月 --202212 或 2022-12

select CONVERT(varchar(6),GETDATE(),112) --202212

select CONVERT(varchar(7),GETDATE(),120) --2022-12-14

  1. 获取当前年月日 --20221214 或 2022-12-14

select CONVERT(varchar(8),GETDATE(),112) --20221214

select CONVERT(varchar(10),GETDATE(),120) --2022-12-14

  1. 日期相关函数整理

GETDATE() :获取当前时间,时间格式默认。

DATENAME:参数为两个,取值区间 interval 和时间 date

date 就是时间;

interval 包括 年,月,日,星期等

e.g:

  YEAR 年;YYYY 年;YY 年;
  QUARTER 季度;QQ 季度 ;Q 季度;
  MONTH 月(04);MM 月(04);M 月(04);
  WEEKDAY 星期几;DW 星期几;W 星期几;
  WEEK 一年的第几周;WK 一年的第几周;WW 一年的第几周;ISOWK 一年的第几周;ISOWW 一年的第几周;ISO_WEEK 一年的第几周;
  DAY 天;DD 天;D 天;
  DAYOFYEAR 一年的第几天;DY 一年的第几天;Y 一年的第几天;
  HOUR 小时;HH 小时;
  MINUTE 分钟;MI 分钟;N 分钟;
  SECOND 秒;SS 秒;S 秒;
  MCS 微秒(略);MICROSECOND 微秒(略);MILLISECOND 毫秒(略);MS 毫秒(略) ; NANOSECOND 十亿分之一秒(略);NS 十亿分之一秒(略);

DATEPART:参数参考DATENAME,不过返回值不一样,DATENAME返回varchar,DATEPART返回int

CONVERT 函数转换格式:主要注意第三个参数 date_style ;格式:select CONVERT(varchar,GETDATE(),0)

    最后的 date_style 可以有 0,1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,100,101,102,103,104,105,106,107,108,109,110,111,112,113,114,120,121,126,127,130,131等

    常用的 20,23,24,102,111,112,120等;

示例:

select CONVERT(varchar,GETDATE(),20)  --2018-04-23 14:44:22
    select CONVERT(varchar,GETDATE(),23)  --2018-04-23
    select CONVERT(varchar,GETDATE(),24)  --14:44:22
    select CONVERT(varchar,GETDATE(),102) --2018.04.23
    select CONVERT(varchar,GETDATE(),111) --2018/04/23
    select CONVERT(varchar,GETDATE(),112) --20180423
  1. 字符串转日期:
select CONVERT(datetime,'2018-04-23',20) 

第三个参数参考以上。

  1. 计算时间差DATEDIFF 函数
功能:返回两个日期之间的间隔。

语法:DATEDIFF ( date-part, date-expression-1, date-expression-2 )

date-part: year | quarter | month | week | day | hour | minute | second | millisecond

https://www.cnblogs.com/Scholars/p/8919094.html
posted @   ꧁༺星星的轨迹方程式༻꧂  阅读(274)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
点击右上角即可分享
微信分享提示