码迷,mamicode.com
首页 > 数据库 > 详细

weblogic11_64下的java.lang.ClassCastException: java.sql.Timestamp cannot be cast to java.sql.Date

时间:2015-07-02 19:40:31      阅读:276      评论:0      收藏:0      [点我收藏+]

标签: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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!