Hibernate操作Blob/Clob时,发生cannot be cast to oracle.sql.BLOB错误分析

来源:互联网 发布:python 获取当前周数 编辑:程序博客网 时间:2024/06/05 14:55

由Hibernate返回的Blob对象实际上是代理类SerializableBlobProxy的实例,提供了java.sql.Blob接口定义的方法(实际上是通过反射的方式),表现得像是个实现java.sql.Blob接口的对象(只是貌似),但实际上是个Proxy类型的实例,因此不能把这个实例转化成oracle.sql.BLOB类型。会发生类型转换异常(java.lang.ClassCastException),提示信息为cannot be cast to oracle.sql.BLOB 

当用System.out.println(blob)输出信息的时候,显示的是oracle.sql.BLOB@10fba68,很具迷惑性。但使用System.out.println(blob.getClass().getName())输出信息的时候,显示的是$Proxy6,这显示了真实的情况,也就是说显示了这个实例的真实面目。

解决方法很简单如下:

SerializableBlobProxy proxy = (SerializableBlobProxy )Proxy.getInvocationHandler(blob);  java.sql.Blob realBlob = proxy.getWrappedBlob(); 
Proxy为java.lang.reflect中的。

1 0
原创粉丝点击