我遇到了按照标题的错误query.getResultList();运行本机查询时在类文件上JsonbHibernateExampleApplicationTests返回 json 对象。
json返回非类型列没有问题。
请协助并让我知道是否需要更多信息。
下面是源代码
public class JsonbHibernateExampleApplicationTests {
@Autowired
private PersonRepository repository;
@Autowired
private ApplicationContext appContext;
@Test
public void contextLoads() {
EntityManagerFactory entityManagerFactory = (EntityManagerFactory) appContext
.getBean("entityManagerFactory");
EntityManager entityManager = entityManagerFactory.createEntityManager();
String sql = "select additional_data from person";
javax.persistence.Query query = entityManager.createNativeQuery(sql);
query.getResultList();
//List<JsonDataUserType> list = (List<JsonDataUserType>) query.getResultList();
/* System.out.println("list:" + list);
for (JsonDataUserType json: list)
{
System.out.println("json:" + json);
}*/
//List<Object[]> objects = query.getResultList();
//System.out.println("result:"+ objects);
}
}
Run Code Online (Sandbox Code Playgroud)
我在实体中将additional_data列指定为自定义json类型
@Type(type = "JsonDataUserType")
private Map<String, String> additionalData;
Run Code Online (Sandbox Code Playgroud)
我无法在此处粘贴所有源代码,您可以在http://vojtechruzicka.com/postgresqls-jsonb-type-mapping-using-hibernate/查看完整源代码
我刚刚将原始源修改为上面的 URL 以运行本机 SQL 查询。
非常感谢,
我找到了替代解决方案。我将additional_datajson 数据转换为文本。
然后我就能得到输出。
请参阅下面的代码。
如果你们有更好的解决方案,请告诉我。可能是 POJO 映射。
String sql = "select CAST(additional_data AS text) from person";
javax.persistence.Query query = entityManager.createNativeQuery(sql);
List list = query.getResultList(); System.out.println("list:" + list);
System.out.println("list 0:" + list.get(0))
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
16342 次 |
| 最近记录: |