有时候在开发的时候可能需要某个时间字段的某个特定的日期,比如说我们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…