项目需要切换服务器,从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。


   重新测试程序,问题得到解决!