标签:weblogic jdbc timestamp java.sql.date weblogic hibernate java.sql.timestamp cannot be cast to java.sql.date
项目需要切换服务器,从server2003切换到server2008上,新环境用的weblogic11_64、Oracle11g
项目部署运行之后,其他一切正常,只有涉及到查询date类型的数据库字段时,会报以下错误:
java.lang.ClassCastException: java.sql.Timestamp cannot be cast to java.sql.Date
按照一般思路,这个异常,是代码中存在类型的强制转换,只要把强制转换的地方修改成合理的类型转换逻辑就可以了。
但是考虑到在系统迁移的过程中,并没有做任何的代码改动,既然旧环境可以正常执行这段代码,新环境报错,可能是在切换过程中有兼容性或者jar包冲突的问题。
解决过程如下:
一、问题定位
1、怀疑的是jdk版本问题,于是在我本机更换相同版本的jdk,结果本地运行正常,排除jdk原因; 2、怀疑是oracle版本的问题,本机连接新环境数据库,运行正常,排除orale版本问题;
3、本地安装同样版本的weblogic,配置JNDI并部署本地部署包,运行,出现同样问题,问题定位!
二、问题分析
报错位置为Hibernate查询结果的处理,Hibernate将查询结果封装成List<Map>类型,可能是Hibernatejar包的问题,但是在配置weblogic环境的时候,已经根据资料将Hibernate的antlr-2.7.6.jar进入到了StartWebLogic.cmd文件中,所以怀疑是weblogic中JDBC驱动包的问题,按照配置antlr-2.7.6.jar的方式把JDBC驱动包重新引用应该可以解决!
三、解决步骤(把Hibernatejar的配置一同写进来,方便以后配置,该部分参考了其他资料)
1、找到antlr-2.7.6.jar和ojdbc14.jar(直接从WEB-INF\lib目录下拷贝)
2、将其复制到weblogic的安装目录下$weblogic_root$\wlserver_10.3\server\lib(理论上可以是其它的任何目录)
3、在weblogic安装目录下找到
$weblogic_root$\user_projects\domains\base_domain\bin\StartWebLogic.cmd文件
4、用文本编辑器打开StartWebLogic.cmd,找到
set CLASSPATH=%SAVE_CLASSPATH%
set SAVE_CLASSPATH=
在前面两行之间增加以下配置
@REM hibernate3
set PRE_CLASSPATH=%WL_HOME%\server\lib\antlr-2.7.6.jar;%WL_HOME%\server\lib\ojdbc14.jar
set CLASSPATH=%PRE_CLASSPATH%;%CLASSPATH%
5、保存,然后重启weblogic。
重新测试程序,问题得到解决!
本文出自 “麦田守望者” 博客,请务必保留此出处http://4614839.blog.51cto.com/4604839/1670229
weblogic11_64下的java.lang.ClassCastException: java.sql.Timestamp cannot be cast to java.sql.Date
标签:weblogic jdbc timestamp java.sql.date weblogic hibernate java.sql.timestamp cannot be cast to java.sql.date
原文地址:http://4614839.blog.51cto.com/4604839/1670229