Hibernate入门学习
什么是Hibernate
Hibernate是一个轻量级的JDBC封装,也就是说,我们可以使用Hibernate来完成原来我们使用JDBC完成的操作,也就是与数据库的交互操作。它是在Dao层去使用的。总而言之,Hibernate就是一个持久层的ORM框架。
什么是ORM
所谓的ORM就是利用描述对象和数据库表之间映射的元数据,自动把Java应用程序中的对象,持久化到关系型数据库的表中。通过操作Java对象,就可以完成对数据库表的操作。可以把ORM理解为关系型数据和对象的一个纽带,开发人员只需要关注纽带一端映射的对象即可。
Hibernate优点
- Hibernate对JDBC访问数据库的代码做了封装,大大简化了数据访问层繁琐的重复性代码。
- Hibernate是一个基于JDBC的主流持久化框架,是一个优秀的ORM实现,它很大程度的简化了dao层编码工作。
- 总结:Hibernate是企业级开发中的主流框架,映射的灵活性很出色。它支持很多关系型数据库。
Hibernate与JPA
JPA和Hibernate之间的关系,可以简单的理解为JPA是标准接口,Hibernate是实现。
那么Hibernate是如何实现与JPA的这种关系的呢。Hibernate主要是通过三个组件来实现的,及hibernate-annotation、hibernate-entitymanager和hibernate-core。
- hibernate-annotation:是Hibernate支持annotation方式配置的基础,它包括了标准的JPA annotation以及Hibernate自身特殊功能的annotation。
- hibernate-core:是Hibernate的核心实现,提供了Hibernate所有的核心功能。
- hibernate-entitymanager:实现了标准的JPA,可以把它看成hibernate-core和JPA之间的适配器,它并不直接提供ORM的功能,而是对hibernate-core进行封装,使得Hibernate符合JPA的规范。
Hibernate入门
创建Maven项目
创建数据库和表
CREATE TABLE `company` (
`id` int unsigned NOT NULL AUTO_INCREMENT,
`name` varchar(200) COLLATE utf8mb4_general_ci NOT NULL,
`owner_id` int unsigned NOT NULL COMMENT '企业管理员id',
`create_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP,
`modify_time` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,
`deleted` tinyint unsigned NOT NULL DEFAULT '0' COMMENT '0-未注销,1-已注销',
`c_address` varchar(200) CHARACTER SET utf8mb4 COLLATE utf8mb4_general_ci DEFAULT NULL,
`c_type` varchar(200) COLLATE utf8mb4_general_ci DEFAULT NULL,
PRIMARY KEY (`id`),
KEY `FK63siivl7176mfbaqr6dmf07aw` (`owner_id`),
CONSTRAINT `FK63siivl7176mfbaqr6dmf07aw` FOREIGN KEY (`owner_id`) REFERENCES `user` (`id`)
) ENGINE=InnoDB AUTO_INCREMENT=72 DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_general_ci;
创建实体类
public class Company {
private Integer id;
private String name;
private Boolean deleted = false;
private Timestamp createTime;
private Timestamp modifyTime;
private Integer ownerId;
private String cAddress;
private String cType;
}
创建Hibernate的相关配置文件
Hibernate的相关配置文件分为两种:
- Xxx.hbm.xml:它主要是用于描述类与数据库中的表的映射关系;
- hibernate.cfg.xml:它是Hibernate框架的核心配置文件。
创建配置映射文件
Company.hbm.xml
<?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.com.rjxy.Entity.Company" table="cst_customer">
<!-- 建立类中的属性与表中的主键相对应 -->
<id name="id" column="id">
<!-- 主键的生成策略,后面会讲,现在使用的是本地生成策略 -->
<generator class="native" />
</id>
<!-- 建立类中的普通属性和表中的字段相对应 -->
<property name="id" column="id" />
<property name="name" column="name" />
<property name="deleted" column="deleted" />
<property name="creatTime" column="creatTime" />
<property name="ModifyTime" column="ModifyTime" />
<property name="ownerId" column="ownerId" />
<property name="cAddress" column="cAddress" />
<property name="cType" column="cType" />
</class>
</hibernate-mapping>
创建核心配置文件
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE hibernate-configuration PUBLIC
"-//Hibernate/Hibernate Configuration DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-configuration-3.0.dtd">
<hibernate-configuration>
<session-factory>
<!-- 下面是三个必须要有的配置 -->
<!-- 配置连接MySQL数据库的基本参数 -->
<property name="hibernate.connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="hibernate.connection.url">jdbc:mysql://</property>
<property name="hibernate.connection.username"></property>
<property name="hibernate.connection.password"></property>
<!-- 配置Hibernate的方言 -->
<property name="hibernate.dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 下面两个是可选的配置哟! -->
<!-- 打印sql语句 -->
<property name="hibernate.show_sql">true</property>
<!-- 格式化sql语句 -->
<property name="hibernate.format_sql">true</property>
<!-- 告诉Hibernate的核心配置文件加载哪个映射文件 -->
<mapping resource="com/rjxy/Entity/Company/hbm.xml"/>
</session-factory>
</hibernate-configuration>