我正在尝试使用此查询在oracle中插入日期和时间:
insert into table_name
(date_field)
values
(to_date('2003/05/03 21:02:44', 'yyyy/mm/dd hh24:mi:ss'))
但是,如果我检查条目的日期是
SUNDAY 03 MAY 2003 00:00:00 CEST
日期正确但时间错误。为什么呢?
这附加在我的所有Oracle表中。
答案 0 :(得分:5)
如果我们插入带有时间元素的日期,Oracle将保留时间元素。默认的Oracle日期格式是DD-MON-YYYY(或-YY),它不显示时间,但时间就在那里。
但是,您使用的客户端在其显示格式中包含时间元素,但它显示为午夜。请放心,这不是正常的Oracle行为。这是正常的Oracle行为:
SQL> insert into table_name
(date_field)
values
(to_date('2003/05/03 21:02:44', 'yyyy/mm/dd hh24:mi:ss')) 2 3 4
5 /
1 row created.
SQL> alter session set nls_date_format = 'DD-MON-YYYY HH24:MI:SS'
2 /
Session altered.
SQL> select * from table_name
2 /
DATE_FIELD
--------------------
03-MAY-2003 21:02:44
SQL>
您的情况的可能解释:
:new.date_field := trunc(:new.date_field);
的前/后插入触发器。虽然我同意你所有的表都有这个你不知道的触发器似乎很神秘。答案 1 :(得分:4)
我想这没关系。
通过格式化结果检查
SELECT to_char(date_field,'yyyy/mm/dd hh24:mi:ss') date_field FROM table_name;
答案 2 :(得分:0)
sql developer的默认日期格式是没有时间组件。更改您的设置用户属性|数据库| NLS(我不知道真正的englisch菜单条目)或以BlueConga写的形式发出查询。