没有 JDBC 类型的方言映射:1111(本机查询)

Ban*_*ech 3 java json

我遇到了按照标题的错误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 查询。

非常感谢,

Ban*_*ech 6

我找到了替代解决方案。我将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)