gpt4 book ai didi

java - Hibernate子类查询: Java. lang.object无法转换为,错误

转载 作者:行者123 更新时间:2023-12-01 12:40:34 24 4
gpt4 key购买 nike

我有三个 Java 类,A 是 A 的父类,B 和 C 是 A 的子类。我有一个 A 的 Hibernate 映射文件,其中映射了 B & C 使用连接子类。现在,当我尝试查询 C 时,我得到 [Ljava.lang.Object;无法转换为 A。 Hibernate 生成的查询是正确的,但为什么它不允许转换为 A?

我尝试了以下查询,均导致相同的错误。

session.createQuery("from Request as req inner join req.category where req.class=Externalrequest and req.requestId=:id");

session.createQuery("from ExternalRequest as ereq inner join ereq.category where ereq.requestId=:id");

其中Request是父类,ExternalRequest和InternalRequest是子类。

这是我的映射文件的基本结构

<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">

<hibernate-mapping>
<class name="Request" table="request" schema="public">
<id name="requestId" type="integer">
<column name="request_id" />
<generator class="sequence" >
<param name="sequence">request_request_id_seq</param>
</generator>
</id>


<many-to-one name="category" column="category" class="RequestCategory" />


<joined-subclass name="ExternalRequest" table="external_request">
<key column="request_id"/>
.........

</joined-subclass>

<joined-subclass name="InternalRequest" table="internal_request">
<key column="request_id"/>
.......
</joined-subclass>
</class>

最佳答案

[Ljava.lang.Object; 是对象数组的字符串表示形式。我认为发生的情况是您试图将查询结果(即 RequestExternalRequest 数组)分配给类 Request 的变量ExternalRequest

关于java - Hibernate子类查询: Java. lang.object无法转换为,错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25143096/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com