getSingleResult在hibernate中返回本机标量查询的代理

时间:2012-01-12 21:03:07

标签: java hibernate jpa

我正在努力将我的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()是假的),我知道它不是一个列表(object instanceof Listfalse

我错过了什么?

2 个答案:

答案 0 :(得分:5)

总结以下问题的评论:

  

q.getSingleResult().getClass().getInterfaces()返回哪些界面?


  

类型为java.sql.Cloborg.hibernate.engine.jdbc.WrappedClobjava.io.Serializable。 [...]我甚至没有意识到该列是一个clob而且我很惊讶EclipseLink正在为我转换为String


看起来EclipseLink非常聪明,如果需要,可以将CLOB(实际上是一个很长的字符序列,就像String)转换为String。使用Hibernate,必须明确地完成。我想这符合JPA规范。

答案 1 :(得分:0)

您是否为hibernate配置了正确的数据库方言?方言用于映射标量值的类型。