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