SQL获取时间的方法总结
2016-06-09 22:27
302 查看
1. 当前系统日期、时间
select getdate()
2. dateadd
在向指定日期加上一段时间的基础上,返回新的 datetime 值
例如:向日期加上2天
select dateadd(day,2,'2014-10-15') --返回:2014-10-17 00:00:00.000
3. datediff
返回跨两个指定日期的日期和时间边界数。
select datediff(day,'2014-09-01','2014-09-18') --返回:17
4. datepart
返回代表指定日期的指定日期部分的整数。
SELECT DATEPART(month, '2014-10-15') --返回 10
5. datename
返回代表指定日期的指定日期部分的字符串
SELECT datename(weekday, '2014-10-15') --返回:星期五
6. day(), month(),year() --可以与datepart对照一下
select 当前日期=convert(varchar(10),getdate(),120) ,当前时间=convert(varchar(8),getdate(),114)
7. select datename(dw,'2014-10-15')
本年第多少周=datename(week,getdate()) ,
今天是周几=datename(weekday,getdate())
函数 参数/功能
GetDate( ) --返回系统目前的日期与时间
DateDiff (interval,date1,date2) --以interval 指定的方式,返回date2 与date1两个日期之间的差值 date2-date1
DateAdd (interval,number,date) --以interval指定的方式,加上number之后的日期
DatePart (interval,date) ---返回日期date中,interval指定部分所对应的整数值
DateName (interval,date) --返回日期date中,interval指定部分所对应的字符串名称
参数 interval的设定值如下:
值 缩 写(Sql Server) Access 和 ASP 说明
Year Yy yyyy 年 1753 ~ 9999
Quarter Qq q 季 1 ~ 4
Month Mm m 月1 ~ 12
Day of year Dy y 一年的日数,一年中的第几日 1-366
Day Dd d 日,1-31
Weekday Dw w 一周的日数,一周中的第几日 1-7
Week Wk ww 周,一年中的第几周 0 ~ 51
Hour Hh h 时0 ~ 23
Minute Mi n 分钟0 ~ 59
Second Ss s 秒 0 ~ 59
Millisecond Ms - 毫秒 0 ~ 999
access 和 asp 中用date()和now()取得系统日期时间;其中DateDiff,DateAdd,DatePart也同是能用于Access和asp中,这些函数的用法也类似
举例:
1.GetDate() 用于sql server :select GetDate()
2.DateDiff('s','2015-07-20','2015-7-25 22:56:32')返回值为 514592 秒
DateDiff('d','2015-07-20','2015-7-25 22:56:32')返回值为 5 天
3.DatePart('w','2015-7-25 22:56:32')返回值为 2 即星期一(周日为1,周六为7)
DatePart('d','2015-7-25 22:56:32')返回值为 25即25号
DatePart('y','2015-7-25 22:56:32')返回值为 206即这一年中第206天
DatePart('yyyy','2015-7-25 22:56:32')返回值为 2005即2005年
SQL Server DATEPART() 函数返回 SQLServer datetime 字段的一部分。
SQL Server DATEPART() 函数的语法是: DATEPART(portion, datetime)
其中 datetime 是 SQLServer datetime 字段和部分的名称是下列之一:
Ms for Milliseconds
Yy for Year
Qq for Quarter of the Year
Mm for Month
Dy for the Day of the Year
Dd for Day of the Month
Wk for Week
Dw for the Day of the Week
Hh for Hour
Mi for Minute
Ss for Second
--1.编写函数,实现按照'年月日,星期几,上午下午晚上'输出时间信息(2016年3月16日星期一下午)
select datename(yy,getdate()) + '年' + datename(mm,getdate()) + '月' + datename(dd,getdate()) + '日' + datename(weekday,getdate()) + case
when datename(hh,getdate()) < 12 then '上午' else '下午' end
--2.编写函数,根据输入时间。输出该天是该年的第几天
select datepart(dy,getdate())
--3.求出随机输出字符‘a-z
select char(97+abs(checksum(newid()))%26)
select char(97+rand()*26)
sql时间格式化:
select CONVERT(varchar, getdate(), 120) 2014-09-12 11:06:08
select convert(varchar(10),getdate() ,120) 2019-04-09
select CONVERT(varchar(12) , getdate(), 23 ) 2016-06-21
select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','') 20140912110608
select CONVERT(varchar(12) , getdate(), 111 ) 2014/09/12
select CONVERT(varchar(12) , getdate(), 112 ) 20140912
select CONVERT(varchar(12) , getdate(), 102 ) 2014.09.12
其它不常用的日期格式转换方法:
select CONVERT(varchar(12) , getdate(), 101 ) 09/12/2014
select CONVERT(varchar(12) , getdate(), 103 ) 12/09/2014
select CONVERT(varchar(12) , getdate(), 104 ) 12.09.2014
select CONVERT(varchar(12) , getdate(), 105 ) 12-09-2014
select CONVERT(varchar(12) , getdate(), 106 ) 12 09 2014
select CONVERT(varchar(12) , getdate(), 107 ) 09 12, 2014
select CONVERT(varchar(12) , getdate(), 108 ) 11:06:08
select CONVERT(varchar(12) , getdate(), 109 ) 09 12 2014 1
select CONVERT(varchar(12) , getdate(), 110 ) 09-12-2014
select CONVERT(varchar(12) , getdate(), 113 ) 12 09 2014 1
select CONVERT(varchar(12) , getdate(), 114 ) 11:06:08.177
获取前几天的日期:convert(char(10),dateadd(day,-12,GetDate( )),120) 注:-12可随意修改
select getdate()
2. dateadd
在向指定日期加上一段时间的基础上,返回新的 datetime 值
例如:向日期加上2天
select dateadd(day,2,'2014-10-15') --返回:2014-10-17 00:00:00.000
3. datediff
返回跨两个指定日期的日期和时间边界数。
select datediff(day,'2014-09-01','2014-09-18') --返回:17
4. datepart
返回代表指定日期的指定日期部分的整数。
SELECT DATEPART(month, '2014-10-15') --返回 10
5. datename
返回代表指定日期的指定日期部分的字符串
SELECT datename(weekday, '2014-10-15') --返回:星期五
6. day(), month(),year() --可以与datepart对照一下
select 当前日期=convert(varchar(10),getdate(),120) ,当前时间=convert(varchar(8),getdate(),114)
7. select datename(dw,'2014-10-15')
本年第多少周=datename(week,getdate()) ,
今天是周几=datename(weekday,getdate())
函数 参数/功能
GetDate( ) --返回系统目前的日期与时间
DateDiff (interval,date1,date2) --以interval 指定的方式,返回date2 与date1两个日期之间的差值 date2-date1
DateAdd (interval,number,date) --以interval指定的方式,加上number之后的日期
DatePart (interval,date) ---返回日期date中,interval指定部分所对应的整数值
DateName (interval,date) --返回日期date中,interval指定部分所对应的字符串名称
参数 interval的设定值如下:
值 缩 写(Sql Server) Access 和 ASP 说明
Year Yy yyyy 年 1753 ~ 9999
Quarter Qq q 季 1 ~ 4
Month Mm m 月1 ~ 12
Day of year Dy y 一年的日数,一年中的第几日 1-366
Day Dd d 日,1-31
Weekday Dw w 一周的日数,一周中的第几日 1-7
Week Wk ww 周,一年中的第几周 0 ~ 51
Hour Hh h 时0 ~ 23
Minute Mi n 分钟0 ~ 59
Second Ss s 秒 0 ~ 59
Millisecond Ms - 毫秒 0 ~ 999
access 和 asp 中用date()和now()取得系统日期时间;其中DateDiff,DateAdd,DatePart也同是能用于Access和asp中,这些函数的用法也类似
举例:
1.GetDate() 用于sql server :select GetDate()
2.DateDiff('s','2015-07-20','2015-7-25 22:56:32')返回值为 514592 秒
DateDiff('d','2015-07-20','2015-7-25 22:56:32')返回值为 5 天
3.DatePart('w','2015-7-25 22:56:32')返回值为 2 即星期一(周日为1,周六为7)
DatePart('d','2015-7-25 22:56:32')返回值为 25即25号
DatePart('y','2015-7-25 22:56:32')返回值为 206即这一年中第206天
DatePart('yyyy','2015-7-25 22:56:32')返回值为 2005即2005年
SQL Server DATEPART() 函数返回 SQLServer datetime 字段的一部分。
SQL Server DATEPART() 函数的语法是: DATEPART(portion, datetime)
其中 datetime 是 SQLServer datetime 字段和部分的名称是下列之一:
Ms for Milliseconds
Yy for Year
Qq for Quarter of the Year
Mm for Month
Dy for the Day of the Year
Dd for Day of the Month
Wk for Week
Dw for the Day of the Week
Hh for Hour
Mi for Minute
Ss for Second
--1.编写函数,实现按照'年月日,星期几,上午下午晚上'输出时间信息(2016年3月16日星期一下午)
select datename(yy,getdate()) + '年' + datename(mm,getdate()) + '月' + datename(dd,getdate()) + '日' + datename(weekday,getdate()) + case
when datename(hh,getdate()) < 12 then '上午' else '下午' end
--2.编写函数,根据输入时间。输出该天是该年的第几天
select datepart(dy,getdate())
--3.求出随机输出字符‘a-z
select char(97+abs(checksum(newid()))%26)
select char(97+rand()*26)
sql时间格式化:
select CONVERT(varchar, getdate(), 120) 2014-09-12 11:06:08
select convert(varchar(10),getdate() ,120) 2019-04-09
select CONVERT(varchar(12) , getdate(), 23 ) 2016-06-21
select replace(replace(replace(CONVERT(varchar, getdate(), 120 ),'-',''),' ',''),':','') 20140912110608
select CONVERT(varchar(12) , getdate(), 111 ) 2014/09/12
select CONVERT(varchar(12) , getdate(), 112 ) 20140912
select CONVERT(varchar(12) , getdate(), 102 ) 2014.09.12
其它不常用的日期格式转换方法:
select CONVERT(varchar(12) , getdate(), 101 ) 09/12/2014
select CONVERT(varchar(12) , getdate(), 103 ) 12/09/2014
select CONVERT(varchar(12) , getdate(), 104 ) 12.09.2014
select CONVERT(varchar(12) , getdate(), 105 ) 12-09-2014
select CONVERT(varchar(12) , getdate(), 106 ) 12 09 2014
select CONVERT(varchar(12) , getdate(), 107 ) 09 12, 2014
select CONVERT(varchar(12) , getdate(), 108 ) 11:06:08
select CONVERT(varchar(12) , getdate(), 109 ) 09 12 2014 1
select CONVERT(varchar(12) , getdate(), 110 ) 09-12-2014
select CONVERT(varchar(12) , getdate(), 113 ) 12 09 2014 1
select CONVERT(varchar(12) , getdate(), 114 ) 11:06:08.177
获取前几天的日期:convert(char(10),dateadd(day,-12,GetDate( )),120) 注:-12可随意修改
相关文章推荐
- 阿里云服务器,数据库热备、暖备、冷备实战-镜像篇(域环境下配置)
- mysql登录用户验证遇到的问题 access denied for user ‘user’@'localhost'
- 用Java开发的MySQL,Oracle,PostgreSQL,mongoDB 数据库web管理工具软件
- orcl sql语句笔记(select成功,update/delete/insert失败问题)
- SQL注入原理讲解,很不错!
- Chapter 3. 数据库约束(设计器操作)
- 数据库必会必知 之 SQL四种语言:DDL DML DCL TCL
- Redis安装与配置
- mysql的主从、主主及半同步复制
- 经典SQL练习题
- MySQL执行sql查询并上传至远程服务器
- MySql-索引优化
- Node.js简单操作MongoDB(CRUD)
- Microsoft.Web.Redis.RedisSessionStateProvider
- MySQL体系结构
- Liunx下修改MySQL字符集
- mysql启动报错Can't read from messagefile处理
- Didcuz memcache+ssrf GETSHELL漏洞解决方法
- mysql和mariadb主库drop表时从库的不同处理方式
- oracle——Hibernate 不同数据库的连接及SQL方言