hibernate Day2 笔记

1、主键生成策略

	<!--映射配置文件
		>映射配置文件名称和位置没法有固定要求
		>映射配置文件中的name属性值写实体类相关内容
		-- class 标签name属性值实体类全路径
		-- id标签和property标签name属性值 实体类的属性名称(注意要完全一样)
		-- id标签和property标签中的column属性是可以省略的,如果不写,则生成的字段名与属性名一样,建议写
		出,这样比较清析。
		-- property标签中 还有一个属性type属性,用于设定字段的类型,我们可以不用使用,这时hibernate会自动
		生成相应的类型    -->
		
		主键生成策略
		<generator class="increment"></generator>    先查询最主键的最大值,然后加一
		<generator class="identity"></generator>     identity要求数据库的主键为自增长类型,采用数据库本身提供的主键生成标识符
		<generator class="uuid"></generator>         uuid要求主键为字符串类型
		<generator class="native"></generator>       native从idenity、sequence、hilo当中选择一种合适的生成策略   

  2、hibernate缓存

计算机领域非常通用的概念。
它介于应用程序和永久性数据存储源(如硬盘上的文件或者数据库)之间,
其作用是降低应用程序直接读写永久性数据存储源的频率,从而提高应用的运行性能。

缓存中的数据是存储源总的数据的拷贝。缓存的物理介质通常是内存。


hibernate一级缓存
	1、默认打开
	2、使用范围:从session创建到session关闭
	3、hibernate一级缓存中,存储的数据必须是持久态的数据,瞬时态和托管态的数据不会存储到一级缓存中
	
hibernate二级缓存
	1、目前已经不使用了,使用redis代替
	2、二级缓存默认是不打开的,需要通过配置打开
	3、二级缓存的范围:是SessionFactory范围(项目范围)
	

验证一级缓存:
	根据uid查询,返回对象(查询数据库,会有sql输出)
	再次根据uid查询,返回对象(不会有sql语句输出)		

效果如下:
	System.out.println("--------------------");
	Person p = (Person)ss.get(Person.class,11);
	System.out.println(p);
	System.out.println("--------------------");
	Person p2 = (Person)ss.get(Person.class,11);
	System.out.println(p2);	

--------------------
Hibernate: 
    select
        person0_.uid as uid0_0_,
        person0_.uname as uname0_0_,
        person0_.pword as pword0_0_,
        person0_.addr as addr0_0_ 
    from
        t_person person0_ 
    where
        person0_.uid=?
Person [uid=11, uname=zs, pword=123, addr=shanghai]
--------------------
Person [uid=11, uname=zs, pword=123, addr=shanghai]

步骤:
	-- 首先查询一级缓存, 查询一级缓存如果没发现有相应的数据, 就去执行数据库查询
	-- 查询数据库后, 会把查询得到的结果放到一级缓存中
	-- 第二次进行查询时, 也会首先进行一级缓存查询, 这时发现数据已经在一级缓存中了, 直接取出就结果, 不会再做数据库的查询
	注意: 一级缓存中并不是存储某个对象, 而是把对象的属性值给存到缓存中, 当我们进行第二次查询时, 返回的
	p2,其实是用之前存放的属性值给重新构建出来的一个新的对象噢, 这一点大家了解


hibernate一级缓存特性
》持久态会自动更新数据库      所以,可以不用写ss.update(...)方法(********)
》持久态会自动更新数据库的执行过程(注意:最后提交事务时,
   比较一级缓存中的内容与快照区的内容是否相同,
   相同,不更新,不相同,调用update方法进行更新)

  3、hibernate事务

什么是事务?
       是指作为单个逻辑工作单元执行的一系列操作,要么完全地执行,要么完全地不执行。
       事务处理可以确保除非事务性单元内的所有操作都成功完成,否则不会永久更新面向数据的资源。

事务代码规则写法(重点掌握)       
>结构
try{
   	开启事务
   	处理代码
   	提交事务
}catch){
  	回滚事务
}finally{
   	释放资源
}   
--------------------------------------------------
	public void test1() {
		SessionFactory sf = null;
		Session ss = null;
		Transaction tx = null;
		try {
			sf = HibernateUtils.getSessionFactory();
			// 使用sessionFactory创建Session对象
			ss = sf.openSession();
			// 开启事务
			tx = ss.beginTransaction();
			// 添加功能
			Person p = new Person();
			p.setUname("王五");
			p.setPword("111");
			p.setAddr("黄埔");
			// 调用session对象的实现方法,完成添加
			ss.save(p);
			// 模拟一个异常
			int x = 10 / 0;
			// 提交事务
			tx.commit();
		} catch (Exception e) {
			// 输出异常信息
			//e.printStackTrace();
			// 有异常,则回滚事务
			/**
			 * 一直事务回滚失败的原因是数据库的原因,
			 * mysql数据库只有InnoDB引擎支持事务;
			 * 默认引擎是MyISAM,不支持事务,
			 * 所以,需要设置数据库的表结构为InnoDB;
			 * 即alter table 表名 ENGINE=InnoDB;
			 * 同时,将方言设置为MySQLInnoDBDialect
			 */
			if (tx != null) {
				ss.clear();
				tx.rollback(); 
				System.out.println("事务回滚!");
			}
		} finally {
			// 关闭资源
			if (ss != null && ss.isOpen()) {
				ss.close();
			}
			if (sf != null && !sf.isClosed()) {
				sf.close();
			}
		}
	}
--------------------------------------------------			

  4、hibernate绑定session

》session类似于jdbc的connection,为了可以安全使用threadLocal
》hibernate已经帮我们实现了与本地线程的绑定的session
》获取与本地线程绑定的session

第一步:在hibernate核心配置文件中配置
<!--本地线程绑定的session-->

  

原文地址:https://www.cnblogs.com/1020182600HENG/p/7424346.html