oracle日期时间型timestamp的深入理解

时间:2021-05-02

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;


声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章