Hibernate_01
1.1.1 Hibernate的概述
1.1.1.1 什么是Hibernate
Hibernate是一个开放源代码的对象关系映射框架,它对JDBC进行了非常轻量级的对象封装,它将POJO与数据库表建立映射关系,是一个全自动的 orm框架,hibernate可以自动生成SQL语句,自动执行,使得Java程序员可以随心所欲的使用对象编程思维来操纵数据库。 Hibernate可以应用在任何使用JDBC的场合,既可以在Java的客户端程序使用,也可以在Servlet/JSP的Web应用中使用,最具革命意义的是,Hibernate可以在应用EJB的J2EE架构中取代CMP,完成数据持久化的重任。
Hibernate是一个持久层的ORM框架。
1.1.1.2 什么是ORM
ORM:ObjectRelational Mapping。对象关系映射。开发语言用的是Java,面向对象的(Object)。使用的数据库是关系型数据库(Relational)。就是将对象与数据库中的表建立一种映射关系,操作对象就可以操作这个表。
1.1.1.3 Hibernate的核心配置文件的配置
Hibernate的核心配置文件有两种方式:
【属性文件的方式】
需要在src下创建一个hibernate.properties文件
配置:key=value
hibernate.connection.driver_class=com.mysql.jdbc.Drvier
属性文件的方式:结构不是很清晰而且这种方式不能加载映射文件。需要手动编写代码才能加载映射文件。
【XML配置文件的方式】
数据库的基本参数:
Hibernate的属性
hibernate.hbm2ddl.auto有几个取值
* none :不使用映射转成DDL。
* create :如果原来有表将原有的表删除。每次都会新创建一个表。测试的时候使用。
* create-drop :如果原来有表将原有的表删除。每次都会新创建一个表。执行完操作以后会将表删除掉。测试的时候使用。
* update :如果数据库中有表使用原来的表。如果没有表会创建一个表。而且可以更新原有表结构。
* validate :不会创建表。校验映射和表结构是否正确
映射文件的加载
1.1.2 Hibernate的常用的API
1.1.2.1 Configuration:配置对象
Configuration是一个配置对象,作用主要有两个,一个用来加载核心配置文件。另一个用来加载映射文件。
【加载核心配置文件】
加载hibernate.properties
Configuration cfg = new Configuration();
加载hibernate.cfg.xml
Configuration cfg = newConfiguration().configure();
【加载映射文件】
// 手动加载映射文件
// configuration.addResource("com/aoli/hibernate/domain/Customer.hbm.xml");
// configuration.addClass(Customer.class);
1.1.2.2 SessionFactory:Session工厂
SessionFactory负责管理Session,管理连接池,管理Hibernate二级缓存。采用了工厂模式,不是一个轻量级的对象。通常情况下一个项目只对应一个SessionFactory就够了。是线程安全的对象。
【抽取Hibernate的工具类】
public class HibernateUtils {
private staticfinal Configuration configuration;
private staticfinal SessionFactory sessionFactory;
static{
configuration = new Configuration().configure();
sessionFactory = configuration.buildSessionFactory();
}
public staticSession openSession(){
return sessionFactory.openSession();
}
}
【配置C3P0连接池】
引入c3p0连接池的jar包:
配置C3P0连接池:
<!-- 配置C3P0连接池 -->
<propertyname="connection.provider_class">org.hibernate.connection.C3P0ConnectionProvider</property>
<!--在连接池中可用的数据库连接的最少数目 -->
<propertyname="c3p0.min_size">5</property>
<!--在连接池中所有数据库连接的最大数目 -->
<propertyname="c3p0.max_size">20</property>
<!--设定数据库连接的过期时间,以秒为单位,
如果连接池中的某个数据库连接处于空闲状态的时间超过了timeout时间,就会从连接池中清除 -->
<propertyname="c3p0.timeout">120</property>
<!--每3000秒检查所有连接池中的空闲连接 以秒为单位-->
<propertyname="c3p0.idle_test_period">3000</property>
1.1.2.3 Session:相当于Connection
Session是Hibernate程序与数据库之间的桥梁。完成CRUD的操作。Session是一个单线程的对象,内部维护了Hibernate的一级缓存。
【Session保存某个对象】
@Test
/**
* 保存客户
*/
public void demo1(){
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
Customer customer = new Customer();
customer.setCust_name("梁");
session.save(customer);//保存对象
tx.commit();
session.close();
}
【Session查询某个对象】
@Test
/**
* 查询某个对象
* 面试:get方法和load方法的区别?
* * get方法采用的是立即加载,执行到该行代码的时候,马上发送SQL语句进行查询。查询之后返回的是真实对象本身。
* 查询一个找不到的对象返回null.
* * load方法采用的是延迟加载(lazy),执行到改行的代码的时候,不会马上发送SQL语句,
* 只有真正使用这个对象的时候(使用这个对象的普通属性的时候)才会发送SQL语句。
* load方法返回的是代理对象。(产生的是Customer的子类对象)
* 查询一个找不到的对象抛出异常:ObjectNotFoundException
*/
public void demo2(){
Session session = HibernateUtils.openSession();
Transaction tx= session.beginTransaction();
// 调用session.get()方法查询某个对象。
// Customer customer = session.get(Customer.class, 100l);// 马上发送SQL语句.
// 调用session.load()方法查询某个对象。
Customer customer = session.load(Customer.class,300l);// 不会马上发送SQL语句.
System.out.println(customer);
tx.commit();
session.close();
}
【Session中修改某个对象的方法】
@Test
/**
* 修改某个对象
*/
public void demo3(){
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// 1.直接创建对象进行修改.(没有设置的属性会被修改为null)
/*Customercustomer = new Customer();
customer.setCust_id(4l);
customer.setCust_name("梁如花");
session.update(customer);*/
// 2.先查询再修改.(推荐)
Customer customer = session.get(Customer.class,4l);
customer.setCust_name("梁如花");
session.update(customer);
tx.commit();
session.close();
}
【Session删除某个对象的方法】
@Test
/**
* 删除某个对象
*/
public void demo4(){
Session session = HibernateUtils.openSession();
Transaction tx = session.beginTransaction();
// 1.直接new对象删除
/*Customercustomer = new Customer();
customer.setCust_id(2l);
session.delete(customer);*/
// 2.先查询,在删除(推荐)
Customer customer = session.get(Customer.class, 3l);
session.delete(customer);
tx.commit();
session.close();
}