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包

Hibernate 学习(一)

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);
     }
 }

相关推荐