一尘不染

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()是false),我也不是列表(object instanceof Listis false)。

我想念什么?


阅读 235

收藏
2020-06-20

共1个答案

一尘不染

总结问题下方的评论:

q.getSingleResult().getClass().getInterfaces()返回什么接口?


这类型的java.sql.Cloborg.hibernate.engine.jdbc.WrappedClobjava.io.Serializable。[…]我什至没有意识到该列是Clob,我很惊讶EclipseLink为我执行了到String的转换


看起来EclipseLink很聪明,可以根据需要将CLOB(实际上是一个很长的字符序列,就像String)转换为String。使用Hibernate必须明确地做到这一点。我猜这符合JPA规范。

2020-06-20