Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行。
1、首先创建好一个数据库HibernateDB,在创建一张表product_
2、创建一个Java Project工程Hibernate,并导入所需要的包,在工程下创建一个lib文件夹,可以将包直接拖到该文件下
导包步骤: 右键project->property->java build path->libaries->add external jars
3、创建实体类 Product 用于映射数据库中的表product_
4、配置Product.hbm.xml
在包entity(和实体类Product一个包名下)下 新建一个配置文件Product.hbm.xml, 用于映射Product类对应数据库中的product_表
<?xml version="1.0"?>
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD 3.0//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<hibernate-mapping package="entity">
<!-- 注: 文件名 Product.hbm.xml P一定要大写,要和类保持一致 -->
<!-- 表示类Product对应表product_ -->
<class name="Product" table="product_">
<!-- 表示属性id,映射表里的字段id -->
<id name="id" column="id">
<generator class="native">
</generator>
</id>
<property name="name" />
<property name="price" />
</class>
</hibernate-mapping>
5、配置hibernate.cfg.xml
在src目录下创建 hibernate.cfg.xml;配置访问数据库要用到的驱动,url,账号密码等等
<?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>
<!-- Database connection settings -->
<property name="connection.driver_class">com.mysql.cj.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/HibernateDB?characterEncoding=UTF-8</property>
<property name="connection.characterEncoding">utf-8</property>
<property name="connection.username">root</property>
<property name="connection.password">admin</property>
<!-- SQL dialect -->
<!-- 这表示使用MYSQL方言。 什么方言呢? 因为在代码层面,开发人员不用关心底层到底用Oracle还是Mysql,写的代码都是一样的。 可是Oracle和Mysql所用的sql语句的语法是有所区别的,那么这件事就交给Hibernate来做了。这个时候就需要告诉Hibernate底层用的是什么数据库,它才知道应该用什么样的“方言” 去对话。 -->
<property name="dialect">org.hibernate.dialect.MySQLDialect</property>
<!-- 这是Hibernate事务管理方式,即每个线程一个事务 -->
<property name="current_session_context_class">thread</property>
<!-- 这表示是否在控制台显示执行的sql语句 -->
<property name="show_sql">true</property>
<!-- 这表示是否会自动更新数据库的表结构,有这句话,其实是不需要创建表的,因为Hibernate会自动去创建表结构 -->
<property name="hbm2ddl.auto">update</property>
<!-- 这表示Hibernate会去识别Product这个实体类 -->
<mapping resource="entity/Product.hbm.xml" />
</session-factory>
</hibernate-configuration>
6、再创建一个测试类TestHibernate
hibernate的基本步骤是:
(1) 获取SessionFactory
(2)通过SessionFactory 获取一个Session
(3)在Session基础上开启一个事务
(4)通过调用Session的save方法把对象保存到数据库
(5)提交事务
(6)关闭Session
(7)关闭SessionFactory
package hibernate;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.cfg.Configuration;
import entity.Product;
/* Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行
* hibernate的基本步骤是:
1. 获取SessionFactory
2. 通过SessionFactory 获取一个Session
3. 在Session基础上开启一个事务
4. 通过调用Session的save方法把对象保存到数据库
5. 提交事务
6. 关闭Session
7. 关闭SessionFactory
* */
public class TestHibernate {
public static void main(String[] args) {
//1. 获取SessionFactory
SessionFactory sf = new Configuration().configure().buildSessionFactory();
//2. 通过SessionFactory 获取一个Session
Session session = sf.openSession();
//3. 在Session基础上开启一个事务
session.beginTransaction();
Product product = new Product();
product.setName("iPhone12");
product.setPrice(7000);
//4. 通过调用Session的save方法把对象保存到数据库
session.save(product);
//5. 提交事务
session.getTransaction().commit();
//6. 关闭Session
session.close();
//7. 关闭SessionFactory
sf.close();
}
}
这时查询一下表product_,发现已经有了该条数据
7、基本原理
应用程序通过Hibernate把 一个 Product对象插入到数据库的product_表中
hibernate.cfg.xml 配置文件提供链接数据库的基本信息
账号 密码 驱动 数据库ip 端口
Product.hbm.xml 提供对象与表的映射关系
对应哪个表? 什么属性,对应什么字段