在上一篇博客中,我们通过xml配置文件进行实体类和表的映射,但是近两年来有更多的项目对一些比较稳定的实体类使用了注解进行ORM映射,这样使得编程更加简洁、简单。其实使用注解进行ORM映射和使用xml进行映射没有太多的操作流程上的变化,主要步骤为:导包、编写带注解的实体类、编写核心配置文件、编写测试类。
项目工程代码已经上传到GitHub:https://github.com/wanyouxian/Hibernate 工程名:HibernateUseAnnotation
整个工程项目结构如下图:
一、导包
笔者使用的是MySQL数据库,因此导入数据包如下图:
二、编写实体类
用于映射的注解基本都在javax.persistence.*包中定义,我常用到的主要是如下四个:
@Entity注释将此类标记为实体。
@Table注释指定要保留此实体的数据的表名。 如果不使用@Table注释,hibernate将使用类名作为表名称bydefault。
@Id注释标记此实体的标识符。
@Column注释指定此属性或字段的列的详细信息。如果未指定@Column注释,则属性名称将用作列名称bydefault。

1 package com.rocky.domain; 2 3 import javax.persistence.Entity; 4 import javax.persistence.Id; 5 import javax.persistence.Table; 6 7 @Entity 8 @Table(name = "tb_user") 9 public class User 10 { 11 @Id 12 private Integer uId; 13 private String uName; 14 private Integer uAge; 15 public User() 16 { 17 super(); 18 } 19 @Override 20 public String toString() 21 { 22 return "User [uId=" + uId + ", uName=" + uName + ", uAge=" + uAge + "]"; 23 } 24 public Integer getuId() 25 { 26 return uId; 27 } 28 public void setuId(Integer uId) 29 { 30 this.uId = uId; 31 } 32 public String getuName() 33 { 34 return uName; 35 } 36 public void setuName(String uName) 37 { 38 this.uName = uName; 39 } 40 public Integer getuAge() 41 { 42 return uAge; 43 } 44 public void setuAge(Integer uAge) 45 { 46 this.uAge = uAge; 47 } 48 }
三、编写核心配置文件
使用注解的配置文件和xml映射的配置文件基本大同小异,但是在引入外部映射时使用的属性是class而非resource属性。

1 <?xml version='1.0' encoding='UTF-8'?> 2 <!DOCTYPE hibernate-configuration PUBLIC 3 "-//Hibernate/Hibernate Configuration DTD 3.0//EN" 4 "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd"> 5 6 <hibernate-configuration> 7 <session-factory> 8 9 <!--指定数据库的参数 --> 10 <property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property> 11 <property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property> 12 <property name="hibernate.connection.url">jdbc:mysql://192.168.100.100:3306/test</property> 13 <property name="hibernate.connection.username">root</property> 14 <property name="hibernate.connection.password">1</property> 15 16 <!--指定hibernate是否显式SQL语句及其格式化 --> 17 <property name="hibernate.show_sql">true</property> 18 <property name="hibernate.format_sql">true</property> 19 20 <!--指定表的生成方式-即是否由hibernate自动创建表,其取值为:create-drop、 21 create、validate、update--> 22 <property name="hibernate.hbm2ddl.auto">update</property> 23 24 <!--引入 ORM配置文件 --> 25 <mapping class="com.rocky.domain.User"/> 26 </session-factory> 27 28 </hibernate-configuration>
四、编写测试类

1 package com.rocky.testdriver; 2 3 import org.hibernate.Session; 4 import org.hibernate.SessionFactory; 5 import org.hibernate.Transaction; 6 import org.hibernate.cfg.Configuration; 7 8 import com.rocky.domain.User; 9 10 public class TestDriver 11 { 12 13 public static void main(String[] args) 14 { 15 // 加载配置文件 16 Configuration cfg = new Configuration(); 17 cfg.configure(); 18 // 创建会话工厂 19 SessionFactory factory = cfg.buildSessionFactory(); 20 // 获取非线程绑定会话 21 Session session = factory.openSession(); 22 // 开启事务 23 Transaction tx = session.beginTransaction(); 24 // 创建User对象 25 User user = new User(); 26 user.setuId(1); 27 user.setuName("rocky"); 28 user.setuAge(28); 29 30 // 将数据插入数据库 31 session.save(user); 32 33 // 提交事务 34 tx.commit(); 35 // 关闭会话 36 session.close(); 37 } 38 39 }