我需要通过在 Hibernate 中执行本机查询来获取结果集。虽然我使用的是 EntityManager,但查询和结果集可能不是实体。
需要获取 List 的 ResultSet。由于选择输出可能会有所不同(读取动态),因此我无法使用 SqlResultSetMapping。
当我尝试下面的代码时,我得到了结果。因为我要求的是单值结果。(休眠JPA)
Query query = manager.createNativeQuery("select name from fresher_test where id=1");
List<Object> amount = query.getResultList();
if(amount == null)
{
System.out.println("Hey its a null");
return;
}
for(Object e : arr)
{
System.out.println(e.toString());
}
输出是:爱丽丝
当我尝试使用 Query 作为选择名称从同一个代码中获取多个选择时,指定来自fresher_test where id=1
输出为:[Ljava.lang.Object;@8b1a4f
一个东西。如何从该对象中获取字段?我试图将对象 e (List l = (List) e;) 类型转换为 List,但我抛出 java.lang.ClassCastException: java.lang.String cannot be cast to java.util.List。
这有一种方法可以让我获取 List 或 Array 中的值??
注意:我不能使用结果类/实体,因为结果可能是动态的。