oracle日期时间型timestamp的深入理解
程序员文章站
2023-11-28 08:28:58
1、字符型转成timestamp复制代码 代码如下:select to_timestamp('01-10月-08 07.46.41.000000000 上午','dd-mo...
1、字符型转成timestamp
select to_timestamp('01-10月-08 07.46.41.000000000 上午','dd-mon-yy hh:mi:ss.ff am')
from dual;
2、timestamp转成date型
select cast(to_timestamp('01-10月-08 07.46.41.000000000 上午','dd-mon-yy hh:mi:ss.ff am') as date) timestamp_to_date
from dual;
3、date型转成timestamp
select cast(sysdate as timestamp) date_to_timestamp
from dual;
4、获取timestamp格式的系统时间
select systimestamp from dual;
5、两date的日期相减得出的是天数,而两timestamp的日期相减得出的是完整的年月日时分秒小数秒
select systimestamp-systimestamp from dual;
select sysdate-sysdate from dual;
注:所以,timestamp要算出两日期间隔了多少秒,要用函数转换一下。
6、to_char函数支持date和timestamp,但是trunc却不支持timestamp数据类型。
7、timestamp只支持秒的小数点后面六位。
select to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6') from dual;
注:ssxff6也可以为ssxff7、ssxff8、ssxff9等,但只到6有效。
8、获取系统时间的语句:
select sysdate,systimestamp,to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6') from dual;
复制代码 代码如下:
select to_timestamp('01-10月-08 07.46.41.000000000 上午','dd-mon-yy hh:mi:ss.ff am')
from dual;
2、timestamp转成date型
复制代码 代码如下:
select cast(to_timestamp('01-10月-08 07.46.41.000000000 上午','dd-mon-yy hh:mi:ss.ff am') as date) timestamp_to_date
from dual;
3、date型转成timestamp
复制代码 代码如下:
select cast(sysdate as timestamp) date_to_timestamp
from dual;
4、获取timestamp格式的系统时间
复制代码 代码如下:
select systimestamp from dual;
5、两date的日期相减得出的是天数,而两timestamp的日期相减得出的是完整的年月日时分秒小数秒
复制代码 代码如下:
select systimestamp-systimestamp from dual;
select sysdate-sysdate from dual;
注:所以,timestamp要算出两日期间隔了多少秒,要用函数转换一下。
6、to_char函数支持date和timestamp,但是trunc却不支持timestamp数据类型。
7、timestamp只支持秒的小数点后面六位。
复制代码 代码如下:
select to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6') from dual;
注:ssxff6也可以为ssxff7、ssxff8、ssxff9等,但只到6有效。
8、获取系统时间的语句:
复制代码 代码如下:
select sysdate,systimestamp,to_char(systimestamp, 'yyyymmdd hh24:mi:ssxff6') from dual;