Hibernate 学习(一)
一、Hibernate 简介
1、Hibernate 简介
Hibernate是一个开放源代码的对象关系映射(ORM)框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。Hibernate 是传统 Java 对象和数据库服务器之间的桥梁,用来处理基于 O/R 映射机制和模式的那些对象。
2、Hibernate 优缺点
优点与缺点都是相对的,那么讲一个东西的优缺点我们都需要一个参数对比,而咱们要来进行对比的咱们操作数据的原生的JDBC:
1、JDBC的优缺点
本质:处理Java对象和关系型数据库表之间的转换。
优点:
操作数据库最底层,性能最高(需要你是有相应的经验,并且是一个数据库高手)。
缺点:
1、使用复杂(重复代码太多)。
2、移植数据库很麻烦,改动比较多;主键的生成方式不同(mysql使用自增,oracle使用序列);分页的sql语句也是不同(mysql使用limit,oracle使用ROWNUM)。
3、性能优化得自己处理,没有提供数据的缓存。
4、面向sql语句操作,不是面向对象的。
2、hibernate的优缺点
本质:处理Java对象和关系型数据库表之间的转换,只是对JDBC再次做了一层封装。
优点:
1、程序员操作很简单,代码简单 session.save(user);
2、直接面向对象操作。
3、提供世界级数据缓存(现在几乎所有的ORM框架的缓存都是学的Hibernate);一级缓存,二级缓存,查询缓存。
4、数据库移植性很强,很少的修改;把各种数据库抽取了一个方言接口;不同数据库实现一个方言接口,如果换了数据库,必须修改方言实现,驱动jar文件,连接数据库信息。
缺点:
1、不能干预sql语句的生成;session.get(User.class,id); 默认查询t_user表的所有字段,自动生成select user0_.id,user0_.name,user0_.age from t_user user0_ where user0_.id=?
2、一个项目中,如果对sql语句的优化要求比较高,不适合用hibernate(不过可以使用 Hibernate 对原生sql 的支持来解决)。
3、如果一张表中有上亿级别的数据量,也不适合用hibernate,其实也不适合用jdbc(可以使用数据库读写分离,分库分表方案解决)。
二、Hibernate 入门
1、步骤
1、拷贝jar包

2、建立 pojo
Product 类:
package com.hibernate.pojo;
/**
* @author zt1994 2018/3/6 14:16
*/
public class Product {
private Integer id;
private String name;
private float price;
public Integer getId() {
return id;
}
public void setId(Integer id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public float getPrice() {
return price;
}
public void setPrice(float price) {
this.price = price;
}
}3、建立映射文件
Product.hbm.xml 映射文件:
<!DOCTYPE hibernate-mapping PUBLIC
"-//Hibernate/Hibernate Mapping DTD//EN"
"http://www.hibernate.org/dtd/hibernate-mapping-3.0.dtd">
<!--映射文件-->
<hibernate-mapping package="com.hibernate.pojo">
<!--class表示一个由hibernate管理的持久对象,对应数据库中一个表-->
<!--table数据库的表名-->
<class name="Product" table="product">
<id name="id" type="int" column="id">
<!--generator表示主键的生成方式,native自动选择数据库本地的策略-->
<generator class="native"/>
</id>
<!--非主键属性-->
<property name="name" column="name" type="string"/>
<property name="price" column="price" type="float"/>
</class>
</hibernate-mapping>4、建立hibernate核心配置文件
hibernate.cfg.xml 配置文件
<?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核心配置文件-->
<hibernate-configuration>
<session-factory>
<property name="dialect">
org.hibernate.dialect.MySQLDialect
</property>
<!--链接池配置-->
<property name="connection.driver_class">com.mysql.jdbc.Driver</property>
<property name="connection.url">jdbc:mysql://localhost:3306/how2java</property>
<property name="connection.username">root</property>
<property name="connection.password">admin</property>
<!--显示sql语句-->
<property name="show_sql">true</property>
<!-- 映射文件-->
<mapping resource="mapper/Product.hbm.xml"/>
</session-factory>
</hibernate-configuration>5、编辑dao实现类
dao 接口:
package com.hibernate.dao;
import com.hibernate.pojo.Product;
import java.util.List;
public interface IProductDao {
/**
* 添加产品
* @param product
* @return
*/
void addProduct(Product product);
}dao 实现:
package com.hibernate.dao.impl;
import com.hibernate.dao.IProductDao;
import com.hibernate.pojo.Product;
import org.hibernate.Query;
import org.hibernate.Session;
import org.hibernate.SessionFactory;
import org.hibernate.Transaction;
import org.hibernate.cfg.Configuration;
import java.util.List;
/**
* @author zt1994 2018/3/6 14:40
*/
public class ProductDaoImpl implements IProductDao {
@Override
public void addProduct(Product product) {
//1.读取并解析配置文件
Configuration configuration = new Configuration();
//2.加载配置文件,如果不设置加载默认配置文件hibernate.cfg.xml
configuration.configure("hibernate.cfg.xml");
//3.生成会话工厂
SessionFactory sessionFactory = configuration.buildSessionFactory();
//4.获取session
Session session = sessionFactory.openSession();
//5.开启事务
Transaction transaction = session.getTransaction();
transaction.begin();
//6.操作CRUD
session.save(product);
transaction.commit();
//7.关闭资源
session.close();
sessionFactory.close();
}
}6、测试
package com.hibernate.test;
import com.hibernate.dao.IProductDao;
import com.hibernate.dao.impl.ProductDaoImpl;
import com.hibernate.pojo.Product;
import org.junit.Test;
/**
* @author zt1994 2018/3/6 14:47
*/
public class TestProductDao {
private IProductDao productDao = new ProductDaoImpl();
/**
* 测试添加商品
*/
@Test
public void testAddProduct(){
Product product = new Product();
product.setName("test");
product.setPrice(2222);
productDao.addProduct(product);
}
}