Hibernate总结(一)
- Hibernate为了提高性能,提供了缓存与快照机制。
它的缓存分为一级缓存与二级缓存。
Hibernate一级缓存:当一个事务中执行一次Sql语句时,就将返回的结果存储在Session中的Map集合中(当然,还有快照)。
- 测试:(以下所有代码处于try/catch块中)
Configuration config=new Configuration().configure();//configure()方法是加载src/hibernate.cfg.xml配置文件
SessionFactory sf=config.buildSessionFactory();
Session s=sf.openSession();//Session是高一级的对Connection的封装
Transaction tran=null;
try {
tran=s.beginTransaction(); //代码在此
tran.commit();
} catch (HibernateException e) {
if(tran!=null){
tran.rollback();
}
e.printStackTrace();
} finally{
s.close();
sf.close();
}
- 查询:包括get(),load(),原生Sql,HQL,Criteria(比HQL更面向对象的一种查询方式)
//1.get(),load()方法测试
User u=(User) s.get(User.class, 1);//第一次查询生成SQL语句,并将结果放入缓存
User u1=(User) s.get(User.class, 1);//第二次查询并无生成SQL语句,但结果取自缓存
p(u==u1);//true
//2.HQL查询
Query q=s.createQuery("from domain.User where id=1");
User u2=(User) q.uniqueResult();//第三次查询生成了SQL语句,但结果取自缓存
p(u2==u);//true
//3.原生Sql
SQLQuery q1=s.createSQLQuery("select * from User where id=1");
q1.addEntity(User.class);
User u3=(User) q1.uniqueResult();//第四次查询生成了SQL语句,但结果取自缓存
p(u3==u);//true
//4.Criteria查询
Criteria c=s.createCriteria(User.class);
c.add(Restrictions.eq("id", 1));
User u4=(User) q1.uniqueResult();//第五次查询生成了SQL语句,但结果取自缓存
p(u4==u);//true
总结查询:
| get(),load() | 原生Sql,HQL,Criteria | |
| Sql语句的缓存 | √ |
X |
| 查询对象的缓存 | √ | √ |
- 增加:save(),persist()
User user = new User();//对象的瞬态
user.setName("xiaobai");
user.setAge(121);
s.save(user);//对象的持久态
s.persist(user);
这里两个方法的区别是:执行方法之前设置主键问题与执行方法之后返回主键问题。
1,persist(),把一个瞬态的实例持久化,但是并"不保证"标识符(identifier主键对应的属性)被立刻填入到持久化实例中,标识符的填入可能被推迟到flush的时候。
2,save(), 把一个瞬态的实例持久化标识符,及时的产生,它要返回标识符,所以它会立即执行Sql insert。
User u = new User();
u.setName("xiaobai");
u.setAge(121);
s.save(u);//插入数据库,并将对象瞬态转为持久态,将返回对象存入缓存
User u1=(User) s.get(User.class, u.getId());//这次查询没有生成SQL语句,结果取自Session的缓存
p(u1==u);//true
- 删除:delete()
User u=(User) s.get(User.class, 10);//执行查询操作
s.delete(u);//将对象持久态转为游离态
当然,如果感觉为了删除一个数据,还的执行查询操作降低性能,可以这样:
User u=new User();
u.setId(5);
s.delete(u);
- 更新:update()
User u=(User) s.get(User.class, 1);
u.setName("set");
但有时候,我们不需要执行s.update(对象)方法,这这涉及到对象的持久态一个特性(也有【快照】作用其中):
当对象为持久态时,当它更新数据时,框架会拿它与之前的快照作比较,若相同,则无动作;若不同,则自动更新至数据库。
//当然,也可以这么做
User u=new User();//对象的瞬态,不具备自动更新功能,需要我们手动update()
u.setAge(1);
u.setId(1);
u.setName("1");
s.update(u);
- 总结:
有一点非常重要:在事务中虽然形成了Sql语句,但只有事务.commit()之后才会真正操作数据库。
Hibernate关于数据库的操作,需要弄清楚【缓存,快照,对象三态】等等些许东西。
对象三态:
* 瞬时态:和hibernate没关联,在数据库表中没有对应的id
* 持久态:和hibernate有关联,在数据库表中有对应的id---OID
* 游离态:和hibernate没关联,在数据库表中有对应的id
Hibernate总结(一)的更多相关文章
- hibernate多对多关联映射
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- 解决 Springboot Unable to build Hibernate SessionFactory @Column命名不起作用
问题: Springboot启动报错: Caused by: org.springframework.beans.factory.BeanCreationException: Error creati ...
- hibernate多对一双向关联
关联是类(类的实例)之间的关系,表示有意义和值得关注的连接. 本系列将介绍Hibernate中主要的几种关联映射 Hibernate一对一主键单向关联Hibernate一对一主键双向关联Hiberna ...
- Hibernate中事务的隔离级别设置
Hibernate中事务的隔离级别,如下方法分别为1/2/4/8. 在Hibernate配置文件中设置,设置代码如下
- Hibernate中事务声明
Hibernate中JDBC事务声明,在Hibernate配置文件中加入如下代码,不做声明Hibernate默认就是JDBC事务. 一个JDBC 不能跨越多个数据库. Hibernate中JTA事务声 ...
- spring applicationContext.xml和hibernate.cfg.xml设置
applicationContext.xml配置 <?xml version="1.0" encoding="UTF-8"?> <beans ...
- [原创]关于Hibernate中的级联操作以及懒加载
Hibernate: 级联操作 一.简单的介绍 cascade和inverse (Employee – Department) Casade用来说明当对主对象进行某种操作时是否对其关联的从对象也作类似 ...
- hibernate的基本xml文件配置
需要导入基本的包hibernate下的bin下的required和同bin下optional里的c3p0包下的所有jar文件,当然要导入mysql的驱动包了.下面需要注意的是hibernate的版本就 ...
- Maven搭建SpringMVC+Hibernate项目详解 【转】
前言 今天复习一下SpringMVC+Hibernate的搭建,本来想着将Spring-Security权限控制框架也映入其中的,但是发现内容太多了,Spring-Security的就留在下一篇吧,这 ...
- 1.Hibernate简介
1.框架简介: 定义:基于java语言开发的一套ORM框架: 优点:a.方便开发; b.大大减少代码量; c.性能稍高(不能与数据库高手相比,较一般数据库使用者 ...
随机推荐
- 《Entity Framework 6 Recipes》中文翻译系列 (27) ------ 第五章 加载实体和导航属性之关联实体过滤、排序、执行聚合操作
翻译的初衷以及为什么选择<Entity Framework 6 Recipes>来学习,请看本系列开篇 5-9 关联实体过滤和排序 问题 你有一实体的实例,你想加载应用了过滤和排序的相关 ...
- SQLite帮助类SQlitehelper 实现对SQLite数据的增删改查
public class SQLiteHelper { public const string sConn = "Data Source=" + @"path" ...
- Oracle 创建普通用户,并赋予权限
采用sys or system / manager as sysdba; 连接数据库. 创建普通用户konglin: create user konglin identified by pwd_ora ...
- Android笔记——permission权限大全
访问登记属性 android.permission.ACCESS_CHECKIN_PROPERTIES ,读取或写入登记check-in数据库属性表的权限 获取错略位置 android.permiss ...
- 深入理解javascript对象系列第三篇——神秘的属性描述符
× 目录 [1]类型 [2]方法 [3]详述[4]状态 前面的话 对于操作系统中的文件,我们可以驾轻就熟将其设置为只读.隐藏.系统文件或普通文件.于对象来说,属性描述符提供类似的功能,用来描述对象的值 ...
- YII 的源码分析(-)
做为源码分析的首秀,我就挑了yii(读作歪依依而不是歪爱爱):它的赞美之词我就不多说了,直接入正题.先准备材料,建议直从官网下载yii的源码包(1.1.15). 在demos里边有一个最简单的应用—h ...
- EntityFramework 7 Join Count LongCount 奇怪问题
先吐槽一下,EF7 目前来说,真对的起现在的版本命名:"EntityFramework": "7.0.0-beta1". 这篇博文纪录一下:当 Linq 查询中 ...
- 【JavaScript】又一神器框架:linq.js
引言 前几天针对一个js数组交集的问题请教了下同事,他第一反应就是循环,这也是常规思路,因为我个人更倾向于js些,我便开玩笑,不知道js能不能像linq那样实现这些操作呢?果断百度了一把,果然有现成框 ...
- Command and Query Responsibility Segregation (CQRS) Pattern 命令和查询职责分离(CQRS)模式
Segregate operations that read data from operations that update data by using separate interfaces. T ...
- 体验VS2015 Update 2 的 Android 和 Python
趁着假期不用加班,又遇到build 2016的劲爆消息--Xamarin免费集成到VS中 所以立马把vs升级到update 2体验一下下(之前也体验过). 在安装的时候也是只勾选了部分,不需要太多(全 ...