java.sql的Date,Timestamp与oracle的date 消失的时分秒

1. 代码中java.sql.Date类型的数据插入到oracle数据库后,再在页面上显示出来只含有日期,时间的小时、分和秒都为零。

2. 然后用SQL developer查看oracle的date声明的字段。

测试如下,更新语句包含有日期和时间,但是查出来的数据只含的日期,看不见小时、分和秒。

update job_history set end_date = TO_DATE('20150115 21:23:34','yyyy-mm-dd hh24:mi:ss') where EMPLOYEE_ID = 102 ;
select end_date from job_history where employee_id = 102;


 

问题出在了SQL developer 的初始设置上 Date Format 设置为DD/MM/RR

修改如下 Tool -> Preferences -> Database -> NLS -> Date Format

 

 

修改设置后发现,java.sql.Date类型的数据插入到oracle数据库后,小时,分和秒数据已经丢失

原来java.slq.Date的定义本身是表示日期,不包含时间,把java.sql.Date转换成yy-MM-dd HH:mm:ss,会发现在它不包含时间。

而oracle的date类型是包含日期和时间,精确到秒,而timestamp是比date更精确的时间,可到秒后的六位数。

最终修改把代码中的java.sql.Date 更换了 java.sql.Timestamp

猜你喜欢

转载自sunwonder.iteye.com/blog/2176514
今日推荐