从数据库读取日期型数据的错误记录:argument type mismatch

当我从数据库查询一条带有日期型字段的数据时,报了这个错误:

        java.lang.IllegalArgumentException: argument type mismatch

这是因为从数据库取出来是date类型的值,而我却用String类型的对象去接的,所以就出现了参数格式不匹配的错误。

解决办法:

        将数据库的查询语句中关于日期查询的字段,例:数据库类型为date类型的mdate,改成to_char(mdate,'yyyy/MM/dd HH24:mm:ss') 。其中yyyy/MM/dd表示年月日的格式,而HH24:mm:ss则表示二十四小时制的时、分、秒。

        但是到这里还不够,取出来是不会报错了,但是取出来是个NULL。这因为转型之后,查询出来的字段名就变成了to_char(mdate,'yyyy/MM/dd HH24:mm:ss')   (可以去数据库看一下),这个时候我再去用mdate这个字段名去取值是取不到任何值的,所以还需要最后一步,重命名。

       即,将原来的字段重命名为:to_char(mdate,'yyyy/MM/dd HH24:mm:ss') as mdate,这样再以mdate取值就不会出错也不会是NULL值了。

       总而言之,解决过程非常简单,只需要修改一下查询语句就行啦,over~

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值