getSingleResult在hibernate中返回本机标量查询的代理
我正在努力将我的JPA持久性提供程序从EclipseLink 2.3切换到Hibernate 3.6.5.Final。 问题在于本机查询。 注意:这不是EclipseLink的问题。 我正在尝试从我没有声明实体的表中获取标量值,一个String
。 这是代码:
Query q = em.createNativeQuery("select description from foo where foo_id = ?"); q.setParameter(1, fooId); String description = (String)q.getSingleResult();
使用Hibernate,我得到一个ClassCastException
因为返回的对象实际上是一个代理对象。 我不知道它是什么类型,但我知道它不是一个数组( object.getClass().isArray()
是假的)我知道它不是一个List( object instanceof List
是false
)。
我错过了什么?
总结以下问题的评论:
q.getSingleResult().getClass().getInterfaces()
返回什么接口?
它的类型为
java.sql.Clob
,org.hibernate.engine.jdbc.WrappedClob
和java.io.Serializable
。 […]我甚至没有意识到该列是一个clob,我很惊讶EclipseLink正在为我转换为String
看起来EclipseLink足够智能,可以根据需要将CLOB(实际上是一个很长的字符序列,就像String
)转换为String
。 使用Hibernate,必须明确地完成。 我想这符合JPA规范。
您是否为hibernate配置了正确的数据库方言? 方言用于映射标量值的类型。