我一直在研究各种hibernate教程和示例,因为它们具有标识/主键属性,有些使用Java基本类型,有些使用包装器类型。
private int id;
与
private Integer id;
为什么以及何时将一个用作实体密钥?
从Hibernate的角度来看,它没有任何改变,因为Hibernate使用相同的Hibernate类型来表示它们。
然而,正如字节码忍者指出,你不能区分原始INT的默认值0
从分配的0
同时也有可能没有歧义null
(一个null
ID总是意味着一个新的实体),这就是为什么我更喜欢使用可为null的包装器类型。
这就是Hibernate的建议。从参考文档中:
4.1.2。提供标识符属性(可选)
猫有一个名为id的属性。此属性映射到数据库表的主键列。该属性可能被称为任何东西,并且其类型可能是任何原始类型,任何原始“包装”类型,java.lang.String或java.util.Date。如果您的旧数据库表具有组合键,则可以使用具有这些类型的属性的用户定义的类(请参阅本章后面的有关组合标识符的部分。)
标识符属性严格是可选的。您可以不使用它们,而让Hibernate在内部跟踪对象标识符。但是,我们不建议这样做。
实际上,某些功能仅适用于声明标识符属性的类:
- 分离对象的传递重新连接(级联更新或级联合并)-请参见第10.11节“传递持久性”
- Session.saveOrUpdate()
- Session.merge()
我们建议 您在持久性类上声明以统一名称命名的标识符属性,并 使用可为空(即非原始)类型。
我实际上在我的基类中利用了这一点:
@MappedSuperclass
public class BaseEntity implements Serializable {
private static final long serialVersionUID = 1L;
private Long id;
@Id
@GeneratedValue(strategy = GenerationType.AUTO)
public Long getId() {
return id;
}
public void setId(Long id) {
this.id = id;
}
@Transient
public boolean isNew() {
return (this.id == null);
}
}
问题内容: 我一直在研究各种休眠教程和示例,因为它们具有身份/主键属性,有些使用Java基本类型,有些使用包装器类型。 与 为什么以及何时将实体密钥用作另一个? 问题答案: 从Hibernate的角度来看,它没有任何改变,因为Hibernate使用相同的Hibernate类型来表示它们。 然而,正如字节码忍者指出,你不能区分原始INT的默认值从分配的同时也有可能没有歧义(一个ID总是意味着一个新的
问题内容: 我有一个类似的问题,如下所示,但解决方案无法解决我的问题。 休眠复合主键包含复合外键,如何映射 我正在尝试加入2个表,每个表都有一个带有部分外键引用的复合主键。 在一个: 在BPK中: 上面的方法给我这个异常: 你能帮忙吗? 问题答案: 假设f1和F2唯一标识A并存在于APK中,则可以通过几种方式使用JPA 2.0的派生ID。最容易显示的是: 这里的关键点是B对A的引用控制了外键字段f
问题内容: 我有一个类似的问题,如下所示,但解决方案无法解决我的问题。 休眠复合主键包含复合外键,如何映射 我正在尝试加入2个表,每个表都有一个带有部分外键引用的复合主键。 在一个: 在BPK中: 上面的方法给我这个异常: 你能帮忙吗? 问题答案: 假设f1和F2唯一标识A并存在于APK中,则可以通过几种方式使用JPA 2.0的派生ID。最容易显示的是: 这里的关键点是B对A的引用控制了外键字段f
我有一个类似的问题如下,但解决方案没有解决我的问题。 hibernate复合主键包含复合外键,如何映射此 我试图连接2个表,每个表都有一个复合主键和部分外键引用。 你能帮忙吗?
这两条线有什么区别 和 或者
问题内容: 我想要一个JPA / Hibernate(最好是JPA)批注,它可以生成列的值,该值不是主键,并且它不能从1开始。 从我看到的内容来看,JPA无法使用@GeneratedValue和@SequenceGenerator和@TableGenerator做到这一点。或其他。 我看到了一个带有额外表的解决方案,但我发现它并不优雅。 我可以使用Hibernate注释,因为我已经有了hibern