gpt4 book ai didi

java - Hibernate - 有没有办法将 2 列与 1 列连接起来?

转载 作者:可可西里 更新时间:2023-11-01 06:49:50 25 4
gpt4 key购买 nike

我正在使用 Spring 和 Hibernate 开发网络应用程序。

表 1:基表

+------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+--------------+------+-----+---------+----------------+
| Id | bigint(20) | NO | PRI | | auto_increment |
| Serial1 | varchar(255) | YES | | NULL | |
| Serial2 | varchar(255) | YES | | NULL | |
| ModelNum | varchar(255) | YES | | NULL | |
| ... | .... | .. | 0 | | |
+------------+--------------+------+-----+---------+----------------+

表 2:明细表

+------------+--------------+------+-----+---------+----------------+
| Field | Type | Null | Key | Default | Extra |
+------------+--------------+------+-----+---------+----------------+
| Id1 | varchar(20) | NO | PRI | | |
| Id2 | varchar(20) | NO | PRI | | |
| Id3 | varchar(20) | NO | PRI | | |
| Serial | varchar(255) | YES | | NULL | |
| ... | .... | .. | 0 | | |
+------------+--------------+------+-----+---------+----------------+

我需要根据连续出版物加入表格。 Table2 中的 Serial 可能包含来自 Table1Serial1Serial2 的值,因此它应该像 OR 运算符一样进行比较。我正在为表使用 hbm.xml。没有注释映射。我加入了这样的表格:

<one-to-one name="notes"
class="Notes" entity-name="Notes">
</one-to-one>

我之前使用过这个查询:

SELECT A.* FROM Table2 As a INNER JOIN Table1 As b 
ON (a.Serial = b.Serial1 or a.Serial = b.Serial2);

我经历了这个http://docs.jboss.org/hibernate/orm/3.3/reference/en/html/associations.html但只使用了 1 个键列。

如何使用 HBM.XML 加入此场景?可能吗?

最佳答案

解决方案一

Table1 上创建一个数据库 View ,它公开引用 Table2 的外键。从您发布的查询中投影外键,您无论如何都会将其用于 View 。然后将您的实体映射到 View 。

方案二

使用join formula :

例如,在映射到 Table1 的实体中定义与映射到 Table2 的实体的多对一关联(似乎是您的用例):

@ManyToOne
@JoinColumnsOrFormulas({
@JoinColumnOrFormula(formula=@JoinFormula(value="(SELECT t2.serial FROM Table2 t2 WHERE serial1 = t2.serial OR serial2 = t2.serial)", referencedColumnName="serial"))
})
private Entity2 entity2;

但是,暂时在 Hibernate 中连接公式似乎非常脆弱(我设法使它只适用于多对一关联,我不得不让 Entity2 实现 可序列化;否则它不会工作并抛出一些奇怪的 NullPointer-ClassCastException

关于java - Hibernate - 有没有办法将 2 列与 1 列连接起来?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32012727/

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