三种数据库日期转换对比:
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);
SELECT CAST( DATEPART(yyyy,getdate()) as CHAR(4)) + cast( DATEPART(mm,getdate()) as char(2));
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[, ‘格式’])
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) ;
SELECT CONVERT(char(6),GETDATE(), 112) ;
select convert(char(7) ,GETDATE() , 120)
sqlserver
计算财务年
YEAR(dateadd(MONTH,1,hz.确认时间)) = YEAR(getdate())
mysql
oracle
http://www.w3school.com.cn/sql/func_convert.asp
SELECT CONVERT(varchar(100),GETDATE(), 23) ; -- 2015-07-07SELECT CONVERT(char(6),GETDATE(), 112) ; -- 201507
Sql
Server
时间
转
字符串
SELECT CONVERT(varchar(100), GETDATE(), 0) 05 9 20
11
9:12AM
SELECT CONVERT(varchar(100), GETDATE(), 1) 05/09/
11
SELECT CONVERT(varchar(100), GETDATE(), 2)
11
.05.09
SELECT CONVERT(varchar(100), GETDATE(), 3) 09/05/
11
SELECT CONVERT(varchar
在本文中,GetDate()获得的
日期
由两部分组成,分别是今天的
日期
和当时的时间: Select GetDate() 用DateName()就可以获得相应的年、月、日,然后再把它们连接起来就可以了:
Select Datename(year,GetDate())+'-'+Datename (month,GetDate())+'-'+Datename(...
日期
转
换为
字符串
:"TO_CHAR" (SYSDATE, 'yyyy-MM-dd')
字符串
转
换为
日期
:TO_DATE (str,'yyyy-mm-dd hh24:mi:ss')
但是这里有个要求str 的格式是要 2020-01-01 00:00:00的,斜杆 / 这种是不可以的
如果str长度到日 比如:'2020-01-01' ,是不能
转
换为 yyyy-mm的 只能
转
换不能截取,这里和
mysql
不同。如果想要到月为止,就只能在通过substring截取。
MySQL
中
字符串
比较大小(
日期
字符串
比较问题)
数据库
中在对于数字与非数字混合的
字符串
,在进行大小比较的时候,如果两
字符串
长度相等,那么两
字符串
就会比较相同位置的字符,比较时若字符是数字,则直接比较,若字符是非数字那么会
转
换为ascii码进行比较,若在某位置上已经有大小之分,那么就不会再进行比较。
如上所述,当
字符串
用于比较时间格式数据进行时间维度的比较时会出现问题。如以下
sql
进行查询时
select * FROM work_day_content as wdc WHERE wdc.work_da
在
Oracle
中,可以使用 TO_CHAR 函数将
日期
转
换为
字符串
。
例如,要将
日期
'2022-12-30'
转
换为
字符串
'20221230',可以使用以下语句:
SELECT TO_CHAR(TO_DATE('2022-12-30', 'YYYY-MM-DD'), 'YYYYMMDD') FROM DUAL;
-- Purpose : JSON特殊字符替换
FUNCTION replace_json_char(p_char VARCHAR2) RETURN VARCHAR2 IS
l_char VARCHAR2(20000);
l_temp_char VARCHAR2(100);
BEGIN
FOR i IN 1 .. length(p_char) LOOP
l_temp_char := substr(p_char, i, 1);
可以使用 Flink
SQL
中的 DATE_FORMAT 函数将
日期
转
换为
字符串
。例如,将
日期
字段
转
换为格式为 "yyyy-MM-dd" 的
字符串
,可以使用以下语句:
SELECT DATE_FORMAT(date_field, 'yyyy-MM-dd') FROM table_name;
其中,date_field 是
日期
字段的名称,table_name 是表名。您可以根据需要调整
日期
格式
字符串
。