sql获取时间日期部分内容datepart()和datename()

sql展示时间日期部分内容

sql中取时间日期的各个部分,可以用datapart()和datename(),下面简单介绍下这两个函数。

DATEPART()返回类型:int

功能:
用于返回日期/时间的单独部分,比如年、月、日、小时、分钟等等。
参数格式:

datepart(datepart,date)

date是合法的日期表达式,datepart参考下表:

datepart缩写
yy,yyyy
季度qq,q
mm,m
一年中的第几天dy,y
dd,d
一年中的第几周wk,ww
星期dw,w
小时hh
分钟mi,n
ss,s
毫秒ms
微秒mcs
纳秒ns

DATENAME(), 返回类型:nvarchar

功能:和datapart一样
参数格式:

dataname(datepart,date)

datepart对照和datepart一样可以参考。
举例:
datepart()实例

select datepart(yy,data_time) as '年',
DATEPART(QQ,data_time) as '季',
DATEPART(mm,data_time)as '月',
DATEPART(DD,data_time) as '日',
DATEPART(HH,data_time) as '时',
DATEPART(MI,data_time) as '分',
DATEPART(ss,data_time) as '秒',
DATEPART(MS,data_time) as '毫秒',
DATEPART(MCS,data_time) as '微秒',
DATEPART(NS,data_time) as '纳秒',
DATEPART(DY,data_time) as '一年中第几天',
DATEPART(WK,data_time) as '一年中第几周',
DATEPART(DW,data_time) as '星期几'
from Products

datename实例:

select datename(yy,data_time) as '年',
datename(QQ,data_time) as '季',
datename(mm,data_time)as '月',
datename(DD,data_time) as '日',
datename(HH,data_time) as '时',
datename(MI,data_time) as '分',
datename(ss,data_time) as '秒',
datename(MS,data_time) as '毫秒',
datename(MCS,data_time) as '微秒',
datename(NS,data_time) as '纳秒',
datename(DY,data_time) as '一年中第几天',
datename(WK,data_time) as '一年中第几周',
datename(DW,data_time) as '星期几'
from Products

在这里插入图片描述
说明:
1、通过上边结果可以看出,datepart()返回类型为int,对日期的结果做了运算
2、sql英文版datename(mm,getdate()),得到的是January,中文版得到的结果是01,但是用datepart(mm,getdate())得到的都是int类型1
3、datename(dw,getdate())结果是星期X,datepart(dw,getdate())结果是星期对应的数字

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1.--查询当天: select * from [TABLE] where DateDiff(dd,[dateadd],getdate())=0 2.--查询24小时内的: select * from [TABLE] where DateDiff(hh,[dateadd],getDate())<=24 3.--本月记录 SELECT * FROM [TABLE] WHERE datediff(month,[dateadd],getdate())=0 4.--本周记录 SELECT * FROM [TABLE] WHERE datediff(week,[dateadd],getdate())=0 5.--当前系统日期、时间 select getdate() 6.--在向指定日期加上一段时间的基础上,返回新的 datetime 值(例如:向日期加上2天 ) select dateadd(day,2,'2004-10-15') --返回:2004-10-17 00:00:00.000 7.--返回跨两个指定日期日期和时间边界数。 select datediff(day,'2004-09-01','2004-09-18') --返回:17 8.--返回代表指定日期的指定日期部分的整数。 SELECT DATEPART(month, '2004-10-15') --返回 10 9.--返回代表指定日期的指定日期部分的字符串 SELECT datename(weekday, '2004-10-15') --返回:星期五 10.--day(), month(),year() --可以与datepart对照一下 select 当前日期=convert(varchar(10),getdate(),120),当前时间=convert(varchar(8),getdate(),114) 11.--返回星期几 select datename(dw,'2004-10-15') 12.--返回周和星期 select 本年第多少周=datename(week,'2004-10-15'),今天是周几=datename(weekday,'2004-10-15') 13.--计算到2个时间之间间隔的工作日和工作小时 CREATE FUNCTION dbo.WORKDAYDIFF(@fromDate datetime, @thruDate datetime) RETURNS int AS BEGIN declare @result int set @fromDate = dateadd(day, case when datepart(weekday, @fromDate); % 7 <= 1 then 2 - datepart(weekday, @fromDate); % 7 else 0 end, @fromDate); set @thruDate = dateadd(day, case when datepart(weekday, @thruDate); % 7 <= 1 then -1 - datepart(weekday, @thruDate); % 7 else 0 end, @thruDate); set @result = datediff(hour,@fromDate,@thruDate); / 24 - datediff(week,@fromDate,@thruDate); * 2 if(@result < 0); set @result = 0 return @result END 14.计算哪一天是本周的星期一 SELECT DATEADD(week, DATEDIFF(week,'1900-01-01',getdate()), '1900-01-01') -- 返回2006-11-06 00:00:00.000 或 SELECT DATEADD(week, DATEDIFF(week,0,getdate()),0) 15.当前季度的第一天 SELECT DATEADD(quarter, DATEDIFF(quarter,0,getdate()), 0) —返回2006-10-01 00:00:00.000 16.如何取得某个月的天数 SELECT Day(dateadd(ms,-3,DATEADD(mm, DATEDIFF(m,0,getdate())+1,0))) —返回28

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值