- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用数据库表“persons”实现单表 Hibernate 继承策略。
我有一个家庭,其中有丈夫、妻子、 child 名单和其他囚犯名单。每个人可能是许多家庭的成员(即丈夫可能是一个家庭的丈夫,而另一个家庭的 child )。
@Entity
@Table(name = "families")
public class Family extends BaseObject {
private Parent husband;
private Parent wife;
private String surname;
private List<Child> children = new ArrayList<Child>();
private List<Other> others = new ArrayList<Other>();
@ManyToOne(optional = true, cascade = CascadeType.ALL)
@JoinColumn(name = "husband_id", nullable = true)
public Parent getHusband() {
return husband;
}
@ManyToOne(optional = true, cascade = CascadeType.ALL)
@JoinColumn(name = "wife_id", nullable = true)
public Parent getWife() {
return wife;
}
@LazyCollection(LazyCollectionOption.TRUE)
@ManyToMany(cascade=CascadeType.ALL)
@JoinTable(name="persons_families", joinColumns=@JoinColumn(name="family_id"), inverseJoinColumns=@JoinColumn(name="person_id"))
public List<Other> getOthers() {
return others;
}
@LazyCollection(LazyCollectionOption.TRUE)
@ManyToMany(cascade=CascadeType.ALL)
@JoinTable(name="persons_families", joinColumns=@JoinColumn(name="family_id"), inverseJoinColumns=@JoinColumn(name="person_id"))
public List<Child> getChildren() {
return children;
}
Persons 是所有人的公共(public)类:
@Entity
@Table(name = "persons")
@DiscriminatorColumn(name = "type")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
public class Person extends BaseObject {
private List<Family> families;
@ManyToMany(cascade=CascadeType.ALL)
@ManyToMany(cascade=CascadeType.ALL)
@JoinTable(name="persons_families", joinColumns=@JoinColumn(name="person_id"), inverseJoinColumns=@JoinColumn(name="family_id"))
public List<Family> getFamilies() {
return families;
}
子类、其他类和父类是相同的:
@Entity
@Table(name = "persons")
@DiscriminatorValue(value = "children")
public class Child extends Person {}
@Entity
@Table(name = "persons")
@DiscriminatorValue(value = "others")
public class Other extends Person {}
@Entity
@Table(name = "persons")
@DiscriminatorValue(value = "parents")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
public class Parent extends Person {}
现在在系统启动过程中我遇到以下问题:
org.hibernate.MappingException: Repeated column in mapping for entity: org.parafia.model.Other column: type (should be mapped with insert="false" update="false")
对此我能做什么?我的模型有意义吗?
致以诚挚的问候
最佳答案
Does my model make sense?
事实并非如此:如果您的目标是,比如说,爱丽丝是某个家庭的母亲,同时也是另一个家庭的 child ,那么 type
应该做什么?爱丽丝在persons
中的行是? Alice 应该是 Parent
的实例吗?或Child
?
子类必须是分离集。
关于java - Hibernate继承单表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/48924354/
我习惯于创建基本查询,所以我被困在一个相当复杂的查询上。 Order Number Order Line Package Part Number Size Cost
我想创建类似 tinder/whatsapp 的消息。 我有一个名为“消息”的表,我想显示用户之间的所有对话(最后一条消息) 表结构: message_id | user_id | recipient
我有一个如下所示的表,我想获取每个 loc_id 的最新 insp_date 的 ID (insp_id)。 create table insp ( insp_id int (10),
我正在尝试解决以下问题,如 this table, sql statement and comments 所示 表列:id,版本,idx_on; PK 是“id”列 所以,我从子查询中得到一组元组{i
我正在尝试使用 HQL 创建简单的选择查询。有一个将在查询中使用的实体。它看起来像下面这样: @Entity @Table(name = "my_table") public class MyTabl
我有一个带有单表映射的层次结构。我使用 HSQLDB 进行自动生成 DDL 功能的测试。层次结构中的子类之一具有标量长字段。 我无法保留其他子类的对象,因为第一个类的数据库行字段为空。 Hiberna
我有不同的客户及其信息。所有客户都有相同的信息。一个客户端就是一张表,每个客户端都具有与其他客户端相同的列。 我的问题是,什么更有效或什么更好,或者哪种是实现此目的的最佳方法? 只有一张表包含所有客户
我目前正在开发一个系统,允许使用关键字标记文档并具有以下形式的表格: CREATE TABLE `KeywordsToDocuments` ( `keywordID` int NOT NULL
我有一个成员表:成员(id, name, gender, head_id) 我想要的是建立以户主(家庭成员)为基础的家庭关系。就像这样:一个成员属于一个家庭(由成员定义) 也许我可以将其拆分为 2 个
我有下表: id | billingno | location ------------------------- 1 | 9999999 | Toronto 2 | 9999999 |
我被要求为我们的应用程序考虑一个数据库。大约有7种不同的数据需要存储。一种是标识数据,其中可能包含唯一的序列号、时间、位置。所有其他 6 个数据集(4 个二进制原始数据,2 个文本数据)必须由标识数据
我在 stackoverflow 上搜索过类似的问题,但我不明白如何让它工作,我想做什么... 所以,我想从数据库中获取最近 7 天的交易并获取总销售额,如果某天没有数据,还包括空行。 我目前拥有的:
想象一下以下类别:酒吧、吃饭的地方、商店等...... 每一个分类都会有一些共同的字段,比如 id, name, address and geolocation (Lat and Lng positi
我一直在搜索整个谷歌 - 我可能只是愚蠢地理解答案。 我在 mysql 中有一个表 - 问题。 +-------------+---------------+------+-----+--------
我是 SQL 和 mySQL 的新手,我自学并尝试编写一个查询,向我显示 ID 列中匹配的 ID 的计数为 3 或更少的所有行。 例如: Id timestamp Num
我目前正在处理一个查询,该查询根据书的属性从表中搜索书籍。该表包含超过 5000 万行,结构如下: ----------------------- | book_id | attr_id | --
我是一名优秀的程序员,十分优秀!