Hibernate 4 注解配置

原文: https://javabeginnerstutorial.com/hibernate/hibernate-4-annotations-configuration/

在最后的介绍性文章中,我提到了所谓的“XML 地狱”,它是 XML 在 Hibernate 配置中的大量使用。 在本文中,我将介绍基于注解的配置,您可以在其中使用 Hibernate 在实体上的注解来减少所需的 XML 数量。

为什么注解很好

正如您将在示例代码中看到的那样:使用注解,您可以在实体类定义本身中看到属性映射是什么,因此您无需查找正确的.hbm.xml文件即可查找映射定义。

而且有一个很好的副作用:您只需要修改实体。 例如,如果要向Book类添加新的Date字段,则还需要在Book.hbm.xml文件中添加映射。 使用注解,这只是 Java 类中的更改。 您将在本文后面的示例中找到有关使用日期的示例。

一个示例

在此示例中,我将继续使用第一篇文章中介绍的Book实体。 现在,我将转换 POJO 以使用注解而不是 XML 配置-在本系列的后续部分中,我将继续介绍。 这是因为注解比 XML 更易于阅读和查找。

实体

对于实体,我需要添加一些注解以表示与 XML 文件中相同的映射。

第一个是告诉 Hibernate Book类是一个实体。 我们可以通过@Entity注解来实现。 否则,Hibernate 将在启动时引发异常,并显示错误消息“hibernate_example.Book”是未知实体。

下一个是表定义。 我将书添加到BOOKS表中。 如果没有明确的表定义,Hibernate 会将实体添加到 BOOK表中。 通常,我可以说没有表定义,实体将保存在与实体类相同名称的表中。 要命名表,我必须在类上使用@Table。 该注解具有名为名称的参数。 此名称定义表的名称-因此我添加了此属性并将其命名为 BOOKS

最后,我将 ISBN 定义为实体的 ID。 这是通过@ID注解完成的。

让我们看看整个修改后的实体:

  1. @Entity
  2. @Table(name = "BOOKS")
  3. public class Book {
  4. @Id
  5. private String isbn;
  6. private String title;
  7. private String author;
  8. // other parts stayed the same so I omit them here
  9. }

配置

配置文件需要进行一次修改:我必须在最后将映射标记从使用资源更改为,并提供映射类的限定名称 :

  1. <hibernate-configuration>
  2. <session-factory>
  3. <!-- Database connection settings -->
  4. <property name="connection.driver_class">org.h2.Driver</property>
  5. <property name="connection.url">jdbc:h2:mem:db1;DB_CLOSE_DELAY=-1;MVCC=TRUE</property>
  6. <property name="connection.username">sa</property>
  7. <property name="connection.password"/>
  8. <!-- JDBC connection pool (use the built-in) -->
  9. <property name="connection.pool_size">1</property>
  10. <!-- SQL dialect -->
  11. <property name="dialect">org.hibernate.dialect.H2Dialect</property>
  12. <!-- Disable the second-level cache -->
  13. <property name="cache.provider_class">org.hibernate.cache.internal.NoCacheProvider</property>
  14. <!-- Echo all executed SQL to stdout -->
  15. <property name="show_sql">true</property>
  16. <!-- Drop and re-create the database schema on startup -->
  17. <property name="hbm2ddl.auto">create</property>
  18. <!-- The mapping information of entities -->
  19. <mapping class="hibernate_example.Book"/>
  20. </session-factory>
  21. </hibernate-configuration>

映射文件

可以删除映射文件,因为 Hibernate 不再使用它了。

扩展实体

前面我提到过,添加日期字段有点复杂,因为映射日期并不是那么简单的动作。 为此,我需要在字段上使用@Temporal注解,以告知 Hibernate 我要将日期存储在数据库中,并且当我读取数据库时希望返回日期信息。 javax.persistence.TemporalType告诉我要存储哪种信息。 现在是日期。

  1. @Temporal(TemporalType.DATE)
  2. private Date published;

对于其他正在阅读您的代码的开发人员来说,这很清楚,已将字段published映射为应用和数据库之间的 Date 类型。

对于 XML 配置,我将不得不使用以下配置:

  1. <property name="date" type="date" />

运行应用

该应用也可以像上一篇文章中那样运行,并且结果相同。

总结

Hibernate 可以利用一组标准注解来消除映射 XML 文件的需要。 通过使用标准javax.persistence注解,您可以从 Hibernate 切换到另一个实现标准接口的 ORM 解决方案。

但是,如今有些开发人员正在谈论“注解地狱”,因为您几乎可以使用注解配置任何内容,有时这会使应用的可读性变差。

在下一篇文章中,我将向您展示如何使用 Hibernate 建模实体之间的关系。

代码下载

您可以从 Github 此处下载特定章节的代码。