三种数据库日期转字符串对比sql server、oracle、mysql(V4.11)

18 篇文章 0 订阅
7 篇文章 0 订阅

三种数据库日期转换对比:
http://blog.csdn.net/zljjava/article/details/17552741

SQL类型转换函数:cast(type1 as type2)

数据库中的日期类型

SQL SERVER

DATE 1970-01-01
DATETIME 1970-01-01 00:00:00

Oracle

DATE 2015-08-07 17:34:37
TIMESTAMP 1970-01-01 00:00:00.000000 是DATE的扩展类型,多了小数秒

日期转字符串

oracle

to_char(sysdate,’yyyy-mm-dd’)
select to_char(sysdate,’yyyy-mm-dd hh24:mi:ss’) as nowTime from dual;

sql server

convert(varchar, cast(‘1970-01-01’ as datetime) , 120) 1970-01-01 00:00:00

select convert(char(7),getdate(),20); --2015-10
SELECT CAST( DATEPART(yyyy,getdate()) as CHAR(4)) +  cast( DATEPART(mm,getdate()) as char(2)); -- 201510
Select CONVERT(varchar(100), GETDATE(), 23) --2006-05-16

http://www.cnblogs.com/zhangq723/archive/2011/02/16/1956152.html

mysql

date_format(sysdate(),’%Y-%m-%d’);

字符串转日期

oracle

to_date(sysdate,’yyyy-mm-dd’)
select to_timestamp(‘2012-5-13 18:45:34:567’,’yyyy-mm-dd hh24:mi:ss:ff9’)+0 from dual;

mysql

STR_TO_DATE(sysdate(),'%Y-%m-%d');

数字转为字符串

oracle

(1)使用TO_CHAR函数处理数字
TO_CHAR(number, ‘格式’)
TO_CHAR(salary,’$99,999.99’);
(2)使用TO_CHAR函数处理日期
TO_CHAR(date,’格式’);
to_char(sysdate,’q’) 季
to_char(sysdate,’yyyy’)年
to_char(sysdate,’mm’)月
to_char(sysdate,’dd’)日
to_char(sysdate,’d’)星期中的第几天
to_char(sysdate,’DAY’)星期几
to_char(sysdate,’ddd’)一年中的第几天
to_char(工作时间,’yyyy/mm/dd’) as 工作时间_FORMAT
(3)TO_NUMBER
使用TO_NUMBER函数将字符转换为数字
TO_NUMBER(char[, ‘格式’])
(4) TO_DATE
使用TO_DATE函数将字符转换为日期
TO_DATE(char[, ‘格式’])


sql

1)类型转换:Cast()类型转换,例:Cast(@startdate as datetime),Cast(name as nvarchar)
2)日期截取:Datepart()返回代表指定日期的指定日期部分的整数,例:
Datepart(Dd,@startdate)–取日,
Datepart(Month,@startdate)–取月,
Datepart(Yy,@startdate)–取年
3)日期操作:Dateadd()在向一个日期加上一个段时间的基础上,返回新的datetime类型。例:加2天 Dateadd(day,2,’2009-6-1’)返回:2009-6-3 00:00:00.000


mysql

日期格式转换:date_format(date,format), time_format(time,format)
1)使用DATE_FORMAT(数据库字段,’%Y%m%d’)将时间类型字段格式为”yyyy-mm-dd”字符串格式
2)str_to_date(数据库字段,’%m.%d.%Y’)将字符串类型字段格式为”yyyy-mm-dd”时间格式
3)mysql> select date_format(‘2008-08-08 22:23:00’, ‘%W %M %Y’);

+————————————————+
| date_format(‘2008-08-08 22:23:00’, ‘%W %M %Y’) |
+————————————————+
| Friday August 2008 |
+————————————————+

mysql> select date_format(‘2008-08-08 22:23:01’, ‘%Y%m%d%H%i%s’);

+—————————————————-+
| date_format(‘2008-08-08 22:23:01’, ‘%Y%m%d%H%i%s’) |
+—————————————————-+
| 20080808222301 |
+—————————————————-+

mysql> select time_format(‘22:23:01’, ‘%H.%i.%s’);

+————————————-+
| time_format(‘22:23:01’, ‘%H.%i.%s’) |
+————————————-+
| 22.23.01 |
+————————————-+

MySQL 日期、时间转换函数:date_format(date,format), time_format(time,format) 能够把一个日期/时间转换成各种各样的字符串格式。它是 str_to_date(str,format) 函数的 一个逆转换。
4)
TO_NUMBER用cast就可,但要填适当的类型,示例:

select cast(11 as unsigned int) /整型/

select cast(11 as decimal(10,2)) /浮点型/

SELECT CONVERT(varchar(100),GETDATE(), 23) ; -- 2015-07-07
SELECT CONVERT(char(6),GETDATE(), 112) ; -- 201507
select convert(char(7) ,GETDATE() , 120) -- 2015-07

日期比较

sqlserver

计算财务年
YEAR(dateadd(MONTH,1,hz.确认时间)) = YEAR(getdate())

mysql

oracle

http://www.w3school.com.cn/sql/func_convert.asp

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

C++程序员Carea

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值