本帖最后由 鸭鸭鸭鸭 于 2019-3-21 15:32 编辑
Hibernate JPA入门
1. JPA 介绍
JPA是Java Persistence API的简称,中文名Java持久层API,是JDK 5.0注解或XML描述对象-关系表的映射关系,并将运行期的实体对象持久化到数据库中。Sun引入新JPA ORM规范出于两个原因:其一,简化现有Java EE和Java SE应用开发工作;其二,Sun希望整合ORM技术,实现天下归一 。 其实在5.0出现发布之前,hibernate已经很受大众喜爱了,后来hibernate在3.2版本正式接入JPA 规范,表示自己即属于JPA的框架的具体实现。 一句话概括: JPA 是一种规范、 Hibernate 是这种规范的最好实现。
2. JPA注解建表
平常我们在建表的时候,除了要编写对应的持久化类之外,还要编写对应的hbm 映射文件。 如果需要创建的表比较少,这样做也无可厚非,若是要创建的表很多,那么这样做起来就比较麻烦。 hibernate框架里面提供了对JPA的支持,允许程序员通过JPA的方式 (注解) 来实现持久化类 - 表的映射
1. hbm映射文件建表
本次建表 以学生表为例, 只需要具备几个简单的字段即可。
public class Student {
private Integer id;
private String name;
private int age;
private String phone;
private String address;
//get & set方法
...
}
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping>
<class name="com.itheima.bean.Student" table="t_student">
<id name="id">
<generator class="native"></generator>
</id>
<property name="name"/>
<property name="age"/>
<property name="phone"/>
<property name="address"/>
</class>
</hibernate-mapping>
该部分内容只需要注意映射文件的位置写法
<hibernate-configuration>
<session-factory>
<!-- 1. 核心必须 链接什么数据库, 账号 、 密码-->
...
<!-- 2. 可选配置 -->
...
<!-- 3. 映射文件导入 -->
<mapping resource="com/itheima/bean/Student.hbm.xml"/>
</session-factory>
</hibernate-configuration>
总结
当我们采用普通的xml映射方式来建表,这会让我们的配置文件显得过于的臃肿, 如果项目中的表过多,那么一一对应的关系,就会让我们编写许多映射文件
2. JPA 注解方式建表
持久化类
由于我们的持久化类 & 表的关系都已经使用注解体现出来了, 所以现在可以直接不用编写xml配置文件了。值得注意的是,由于没有了xml配置文件,所以在hibernate的核心配置里面,指定映射的写法也稍有不同。
//表示对应 t_student 这个表
@Entity(name="t_student")
public class Student {
private Integer id;
private String name;
private int age;
private String phone;
private String address;
//只需要在主键的get方法上打注解即可。 官方建议在get方法上打注解
@Id //表示id属性是主键
@GeneratedValue //默认是主键策略 AUTO 方式 , 下文有对该注解作详细描述
public Integer getId() {
return id;
}
//其他的get&set方法
...
此处只需要注意映射文件导入写法即可
<hibernate-configuration>
<session-factory>
<!-- 1. 核心必须 链接什么数据库, 账号 、 密码-->
...
<!-- 2. 可选配置 -->
...
<!-- 3. 映射文件导入 -->
<mapping class="com.itheima.bean.Student"/>
</session-factory>
</hibernate-configuration>
3. 主键策略说明
上面建表的时候,使用的主键注解 @GeneratedValue , 它是JPA 提供主键策略中的一种。 JPA 共提供4中建表策略。
1、AUTO 自动选择一个最适合底层数据库的主键生成策略。如MySQL会自动对应auto increment。这个是默认选项,
即如果只写@GeneratedValue,等价于@GeneratedValue(strategy=GenerationType.AUTO)。注意在mysql5 +
hibernate 5的版本测试下,会产生另外一张表,用于记录主键值。 可以在核心配资文件中添加此属性来达到native效
果
<property name="hibernate.id.new_generator_mappings">false</property>
2、IDENTITY 表自增长字段,Oracle不支持这种方式。
3、SEQUENCE 通过序列产生主键,MySQL不支持这种方式。
4、TABLE 通过表产生主键,框架借由表模拟序列产生主键,使用该策略可以使应用更易于数据库移植。不同的JPA实现
商生成的表名是不同的,如 OpenJPA生成openjpa_sequence_table表,Hibernate生成一个hibernate_sequences
表,而TopLink则生成sequence表。这些表都具有一个序列名和对应值两个字段,如SEQ_NAME和SEQ_COUNT。
4. 关于UUID策略
JPA并没有提供UUID 策略, 好在hibernate提供了关于这种策略的支持。
//声明uuid这种策略类型。然后给定一个别名,叫做jpa-uuid 这个注解是hibernate提供的注解, jpa的注解没有
@GenericGenerator(name="jpa-uuid" ,strategy="uuid")
//表示对应 t_student 这个表
@Entity(name="t_student")
public class Student {
private String id;
private String name;
private int age;
private String phone;
private String address;
//指定使用你的主键策略是 jpa-uuid这个名称对一个你的类型,其实就是指定了主键是uuid 。
//由hibernate来维护主键。
@Id
@GeneratedValue(generator="jpa-uuid")
public String getId() {
return id;
}
...
}
3. 后记
通过以上内容,相信大家对Hibernate 使用JPA 方式建表,已经有所了解了。总体而言,比早前使用xml方式来完成映射的配置,要高效得多。当然JPA 也提供了 表关系的注解,咱们下期在说一说 , 一对多、 多对多的关系映射如何使用JPA方式来建立。
|
|