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-->

  

时间: 2024-08-24 05:24:29

hibernate Day2 笔记的相关文章

《Hibernate学习笔记十一》:树状结构设计

<Hibernate学习笔记十一>:树状结构设计 这是马士兵老师讲解Hibernate的一个作业题,树状结构设计,这是一个比较典型的例子,因此有必要写篇博文记录下. 树状结构的设计,它是在同一个类中使用了多对一(ManyToOne)和一对多(OneToMany). 在完成这个题目我们应该按照如下的步骤进行: 1.先思考数据库的模型应该是什么样的?? 数据库中的模型应该如下:即存在id p_id 2.思考面向对象的模型,及如何来进行映射??? 根据数据库中表的特点,对象应该有id name;由于

hibernate实战笔记1---初探

由于在学习Spring的时候学到有关数据库的章节的时候,提及到了hibernate的集成,但是我对hibernate技术几乎是一点不了解,只是知道它是一个orm对象映射框架,所以在初探的章节做一下hibernate的简单了解,以及应用.顺便提一句,我用的是maven添加的hibernate开发包 简单使用hibernate的一般步骤 *创建并且编辑hibernate配置文件 该配置文件主要是用于链接数据库所用,定义了数据库的驱动程序和映射文件的位置,如下是一个简单的配置 <?xml versio

《Hibernate学习笔记八》:组件映射

<Hibernate学习笔记八>:组件映射 前面介绍了一对一的单向.双向外键关联,例如,学生证和学生是一个一对一的关系.这篇博文主要是介绍下组件映射,即一个是另一个的一部分,例如,学生证的信息也可以作为学生信息的一部分,即在数据库中只存在学生一个表,而不是有学生和学生证两个表,并且这两个表中有一个一对一的关联关系. 如下: 有人或许会说,那我们就将学生和学生证的信息写在一个类中,则就不需要组件映射了,确实可以这样,但是,根据类的设计原则,我们一般都会将其设计为两个类,然后将学生证的信息作为一个

Hibernate学习笔记:第一个程序的搭建

Hibernate学习笔记:第一个程序的搭建 前一段时间对Struts2这个框架有了一点点地了解,很高兴,自己开始学习Hibernate这个框架了.本篇博文将记录下第一个Hibernate程序的搭建过程.其实有时候个人觉得无论我们学习什么语言也好,还是学习什么框架也好,第一个HelloWorld程序真的相当重要,假如 我们在学习第一个HelloWorld程序都跑不出来,这完全影响着我们对新接触的东西的兴趣和动力,但是,往往第一个程序都会涉及到很多的配置,因此使得对于初学者要摸索一定的时间,对于我

hibernate自学笔记

一.hibernate环境搭建 1.下载需要的jar包 hibernate的官方网站是http://www.hibernate.org,hibernate的jar包都可以从官方网站下载得到.推荐下载hibernate-distribution-3.3.2.GA-dist.zip,解压后目录结构 hibernate使用的核心类和接口存放在根目录下hibernate3.jar中 hibernate会使用到一些第三方类库,这些类库放在lib\required下, 名称 说明 antlr-2.7.6.j

hibernate学习笔记之三(一级缓存的使用和管理)

(hibernate学习笔记系列来自于 "疯狂Java" Hibernate视频学习) 一级缓存 一级缓存生命周期很短,与session生命周期一致,所以一级缓存也叫session级缓存或事务级缓存.位于缓存中的对象处于持久化状态,它与表中的相关记录对应,session能够在某些时间点,按照缓存中持久化对象的属性来同步数据库中表的记录,这一过程称为清理缓存. 一级缓存实现原理. session缓存是由它的实现类sessionImpl中定义的一些集合属性构成的,原理是保证有一个引用在关联

hibernate学习笔记之四(Hibernate中的类型)

(hibernate学习笔记系列来自于 "疯狂Java" Hibernate视频学习) Hibernate中的类型 在*.hbm.xml文件中,<property name="password" column="t_pass">,hibernate根据type转换将java转换成hibernate类型,然后再转换成SQL类型,<property name="password" type="...&q

Hibernate学习笔记(3)

两年前曾经学习过Hibernate,也通过博客将Hibernate的学习过程记录下来了,地址如下: Hibernate学习笔记(1) Hibernate学习笔记(2) 最近在复习Hibernate,在重新学习的过程中,有了一些新的体会和收获,现在将其总结成博客,供以后作为参考资料使用. 一.导入相应的jar包 目前Hibernate更新到了4.x版本,在官网下载后,找到lib文件加中的required文件夹,此外还需要额外导入log4j和数据库驱动包. 二.创建Hibernate配置文件 在sr

Hibernate学习笔记(1)Hibernate配置

一 准备工作 首先我们将创建一个简单的基于控制台的(console-based)Hibernate应用程序. 我们所做的第一件事就是创建我们的开发目录,并且把所有需要用到的Java库文件放进去.解压缩从Hibernate网站下载的Hibernate发布包,并把所有需要的库文件拷到我们项目中去. 学习建User-library-hibernate,并加入相应的jar包 (a)项目右键-buildpath-configure build path-add library (b)选择User-libr