当前位置: 首页 > 面试题库 >

休眠主键的基元或包装

梅玉堂
2023-03-14
问题内容

我一直在研究各种休眠教程和示例,因为它们具有身份/主键属性,有些使用Java基本类型,有些使用包装器类型。

 private int id;

 private Integer id;

为什么以及何时将实体密钥用作另一个?


问题答案:

从Hibernate的角度来看,它没有任何改变,因为Hibernate使用相同的Hibernate类型来表示它们。

然而,正如字节码忍者指出,你不能区分原始INT的默认值0从分配的0同时也有可能没有歧义null(一个nullID总是意味着一个新的实体),这就是为什么我更喜欢使用可为null的包装器类型。

这就是Hibernate的建议。从参考文档中:

4.1.2。提供标识符属性(可选)

猫有一个名为id的属性。此属性映射到数据库表的主键列。该属性可能被称为任何东西,其类型可能是任何原始类型,任何原始“包装”类型,java.lang.String或java.util.Date。如果您的旧数据库表具有组合键,则可以使用具有这些类型的属性的用户html" target="_blank">定义的类(请参阅本章后面的有关组合标识符的部分。)

标识符属性严格是可选的。您可以不使用它们,而让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);
    }
}


 类似资料:
  • 问题内容: 我使用Hibernate制作了一个示例应用程序。我的要求是表上没有主键。我只需要从应用程序中选择查询。我知道应该有一个主键,但是我所引用的表没有它。 它有大约5万条记录。因此,修改表以添加ID列将看不到可行的选项。 有可能吗 问题答案: Hibernate 要求 实体表具有主键。故事结局。 在谈论数据库时,5万条记录根本就不多。 我的建议:在表中添加一个自动增量整数PK列。您会对它的速

  • 问题内容: 我有一个胖客户端,带有25个表和约15个JInternalFrames(表的数据输入表单)的架构的java swing应用程序。我需要为DBMS交互选择直接的JDBC或ORM(在这种情况下为Spring框架hibernate)的设计选择。应用程序的构建将在将来发生。 对于这样规模的项目,hibernate会过大吗?对于是或否答案的解释将不胜感激(如果需要,甚至可以采用其他方法)。 TI

  • 问题内容: 我必须与Hibernate合作,但我不确定如何解决此问题,我有2个具有1..n关系的表,如下所示: 如何使用Hibernate进行管理? 我不知道如何声明将包含主键一部分的外键。 我的数据库架构是从Hibernate模型生成的。 问题答案: 我找到了解决此问题的两种方法。 第一个是一种解决方法,没有第二个那么整洁。 将实体的主键定义为包含,和的复合键,首先将假定为主键的内容定义为唯一约

  • 问题内容: 在我的Java应用程序中,我正在使用hibernate .hbm文件访问数据库。是否可以更新表中的主键“ id”列;我的.hbm文件中的“ id”列如下所示: 问题答案: 尝试这个: 或只使用sql:

  • 问题内容: 问题 首先,我想知道我的数据库结构很糟糕,但是目前我无法更改它。 话虽这么说,我需要在Hibernate(4.2.1)中创建一对多的双向关系,该关系不涉及主键(关系的“父”侧仅包含唯一键)并且不涉及联接表。表示这种关系的外键是从“子”到“父”的反向指针(请参见下文)。我已经搜索并尝试了各种不同的注释配置,但是没有运气。我要的是可能的吗? 数据库 GLOBAL_PART PART_REL

  • 问题内容: 我使用spring数据并hibernate@ Filter / @ FilterDef来过滤软删除的实体。似乎springRepository.findOne(id)总是返回值,即使id被软删除。此方法以及通过外键搜索其他字段的where子句中不包含过滤器。在这种情况下是否可以启用过滤器,使其可以用作@Where注释? 问题答案: 我有同样的问题。我已经通过实现HibernatePer