作者热门文章
- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
我正在使用 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
可能包含来自 Table1
的 Serial1
或 Serial2
的值,因此它应该像 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/
我是一名优秀的程序员,十分优秀!