您的位置:首页 > 数据库 > Oracle

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

2016-08-19 14:37 387 查看
由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中的。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  BLOB clob Hibernate oracle