sql server日期函数 怎么查询日期时间

有时候在开发的时候可能需要某个时间字段的某个特定的日期,比如说我们student表中有一个字段是 comeyear (入学日期)
好的,这个是一个datatime类型的,如2012-9-1 12:12:15
我们这个学生是12年9月一号入学的,让我们看一下如何能够获取到年-月-日 小时:分钟:秒

OK!

sql server提供这样的函数给我们查询
比如说我们要查询2015年入学的
使用year函数

select * from student where YEAR(comeyear)=2015

使用month函数查询是9月份入学

select * from student where month(comeyear)=9

使用day函数查询是1号入学

select * from student where day(comeyear)=1

OK ! sql server并没有hour之类的函数可以给我们用,继续

查询上午9点钟入学的

select * from student where datepart(hh,comeyear)=9

查询某个小时14分入学的

select * from student where datepart(mi,comeyear)=9

查询某个小时56秒入学的

select * from student where datepart(ss,comeyear)=56

如果这些还不够用,你还需要更多的系统时间的话,可以考虑convert函数,各种格式的时间(后面的应该是12月14号,也就是当前时间,没有改过来, 自己放到sql语句里面试试就知道了,冒号后面的不要复制–)

--字符串时间

Select CONVERT(varchar(100), GETDATE(), 0): 12 14 2015 10:57AM 
Select CONVERT(varchar(100), GETDATE(), 1): 12/14/15 
Select CONVERT(varchar(100), GETDATE(), 2): 14.12.16 
Select CONVERT(varchar(100), GETDATE(), 3): 14/12/15 
Select CONVERT(varchar(100), GETDATE(), 4): 16.05.15 
Select CONVERT(varchar(100), GETDATE(), 5): 16-05-15 
Select CONVERT(varchar(100), GETDATE(), 6): 16 05 15 
Select CONVERT(varchar(100), GETDATE(), 7): 05 16, 15 
Select CONVERT(varchar(100), GETDATE(), 8): 10:57:46 
Select CONVERT(varchar(100), GETDATE(), 9): 05 16 2015 10:57:46:827AM 
Select CONVERT(varchar(100), GETDATE(), 10): 05-16-15 
Select CONVERT(varchar(100), GETDATE(), 11): 15/05/16 
Select CONVERT(varchar(100), GETDATE(), 12): 150516 
Select CONVERT(varchar(100), GETDATE(), 13): 16 05 2015 10:57:46:937 
Select CONVERT(varchar(100), GETDATE(), 14): 10:57:46:967 
Select CONVERT(varchar(100), GETDATE(), 20): 2015-05-16 10:57:47 
Select CONVERT(varchar(100), GETDATE(), 21): 2015-05-16 10:57:47.157 
Select CONVERT(varchar(100), GETDATE(), 22): 05/16/15 10:57:47 AM 
Select CONVERT(varchar(100), GETDATE(), 23): 2015-05-16 
Select CONVERT(varchar(100), GETDATE(), 24): 10:57:47 
Select CONVERT(varchar(100), GETDATE(), 25): 2015-05-16 10:57:47.250 
Select CONVERT(varchar(100), GETDATE(), 100): 05 16 2015 10:57AM 
Select CONVERT(varchar(100), GETDATE(), 101): 05/16/2015 
Select CONVERT(varchar(100), GETDATE(), 102): 2015.05.16 
Select CONVERT(varchar(100), GETDATE(), 103): 16/05/2015 
Select CONVERT(varchar(100), GETDATE(), 104): 16.05.2015 
Select CONVERT(varchar(100), GETDATE(), 105): 16-05-2015 
Select CONVERT(varchar(100), GETDATE(), 106): 16 05 2015 
Select CONVERT(varchar(100), GETDATE(), 107): 05 16, 2015 
Select CONVERT(varchar(100), GETDATE(), 108): 10:57:49 
Select CONVERT(varchar(100), GETDATE(), 109): 05 16 2015 10:57:49:437AM 
Select CONVERT(varchar(100), GETDATE(), 110): 05-16-2015 
Select CONVERT(varchar(100), GETDATE(), 111): 2015/05/16 
Select CONVERT(varchar(100), GETDATE(), 112): 20150516 
Select CONVERT(varchar(100), GETDATE(), 113): 16 05 2015 10:57:49:513 
Select CONVERT(varchar(100), GETDATE(), 114): 10:57:49:547 
Select CONVERT(varchar(100), GETDATE(), 120): 2015-05-16 10:57:49 
Select CONVERT(varchar(100), GETDATE(), 121): 2015-05-16 10:57:49.700 
Select CONVERT(varchar(100), GETDATE(), 126): 2015-05-16T10:57:49.827 --整数时间

注意

不要吐槽我的入学时间什么的,只是一个测试!!orz…

  • 1
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值