一尘不染

JDBC类型没有方言映射:2003

hibernate

尽管此标题存在一些问题,但我的查询并没有从那些线程中解决。

我正在通过postgres中的hibernate执行递归查询(与子句一起使用),查询结果也包含搜索路径

例如:查询结果的一行

5811;"axyz_3_3";"ABC";5782;5811;5797;4;"**{acl_3_3,acl3_4,acl3,acl_3_3}**";t;t

hibernate状态是否具有"{acl_3_3,acl3_4,acl3,acl_3_3}"String以外的任何映射类型,类似于CHARACTER_ARRAYCHAR_ARRAY

下面是查询输出的示例

id   |name|discri|pId|asscID|immeId|depth|path|cycle|canDelete
5797;"abc3";"abc";5782;5811;5788;7;"{abc_3_3,abc3_4,abc3,abc4}";t;f
5797;"abc3";"abc";5782;5786;5813;6;"{abc1,abc2,abc3,abc3}";t;f
5799;"abc4";"abc";5782;5811;5786;6;"{abc_3_3,abc3_4,abc4}";t;f
5788;"abc2";"abc";5782;5811;5786;6;"{abc_3_3,abc3_4,abc2}";f;f
5786;"abc1";"abc";5782;5786;5799;5;"{abc1,abc2,abc3,abc1}";t;f
5797;"abc3";"abc";5782;5786;5813;5;"{abc1,abc2,abc3,abc3}";t;f
5813;"abc3_4";"abc";5782;5786;5811;5;"{abc1,abc2,abc3_4}";f;f
5786;"abc1";"abc";5782;5811;5799;5;"{abc_3_3,abc4,abc1}";f;f
5813;"abc3_4";"abc";5782;5811;5797;4;"{abc3_4,abc3,abc3_4}";t;f
5811;"abc_3_3";"abc";5782;5811;5797;4;"{abc_3_3,abc3,abc_3_3}";t;t
5799;"abc4";"abc";5782;5811;5797;4;"{abc3,abc4}";f;f

Hibernate抛出异常

Caused by: com.vik.prod.service.UnidentifiedException: No Dialect mapping for JDBC type: 2003
at com.vik.prod.service.ServiceExecutorUtils.execute(ServiceExecutorUtils.java:93)
at com.vik.prod.service.ServerServiceExecutor.execute(ServerServiceExecutor.java:76)
at com.vik.prod.service.ClientDelegate.execute(ClientDelegate.java:197)
... 33 more

原因:org.hibernate.MappingException:没有JDBC类型的方言映射:2003


阅读 200

收藏
2020-06-20

共1个答案

一尘不染

Hibernate不提供Converter类/ Mapper类来转换DB text
[]数据类型,为此,我们可以编写实现UserType的自己的转换类型,或者使用sqlQuery.addScalar(“
path”,Hibernate.TEXT);。我们可以将text []映射到文本,然后在Java代码中将其与’,’分开

2020-06-20