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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值