- 浏览: 181842 次
- 性别:
- 来自: 天津
-
文章分类
最新评论
-
lst923:
...
【转】Java 高性能Web 开发(2)-图像合并实现 CSS Sprites -
静静-黑夜:
离开
jquery uploadify 实现批量上传,带进度显示,判断文件大小 -
lizhao6210126.com:
确认一下这3个参数'multi': true, //是否支持多 ...
jquery uploadify 实现批量上传,带进度显示,判断文件大小 -
hpuyancy:
请问,出问题了,每次仅能上传一个文件,是不是设置的问题呢?
jquery uploadify 实现批量上传,带进度显示,判断文件大小 -
许助云:
例子很好很强大,只不过在调试的时候遇到一个小问题,需要修改to ...
jquery uploadify 实现批量上传,带进度显示,判断文件大小
Hibernate lazy策略:延迟加载、懒加载。
代理的概念:只有真正使用该对象的时候才会创建。
Lazy在hibernate上:在真正使用的时候才会发出sql查询。
实现原理:采用第三方库cglib,对类生成代理类。代理可以控制源对象,并且可以对源对象的功能进行增强。
Cglib和jdk动态代理的区别:
1,cglib能够对类进行代理,jdk动态代理只能对实现了接口的类进行代理。
2,Jdk动态代理类和原类实现相同的接口
3,Cglib 代理类继承原类,生成一个子类。
Lazy在hibernate中的使用地方:可以取值true或false。
* <class>标签,可以取值true或false。默认为true。
* <property> 标签,可以取值true或false。很少用。
* 集合<set><list>,可以取值true、fasle或extra。默认为true。
* <one-to-one> 、<many-to-one> 单端关联上,可以取值false、proxy或noproxy。默认proxy
Load支持lazy,get不支持lazy。并且Load的时候只会加载普通属性,集合不会加载
Lazy的生命周期跟session一样,session关闭,lazy也失效。
Class上的lazy策略:影响的范围是普通属性的加载,对集合不起作用。
session.beginTransaction();
//不会发出sql
Group group = (Group)session.load(Group.class, 1);
//不会发出sql
System.out.println("group.id=" + group.getId());
//会发出sql
System.out.println("group.name=" + group.getName());
session.getTransaction().commit();
Group group = null;
try {
session = HibernateUtils.getSession();
session.beginTransaction();
group = (Group)session.load(Group.class, 1);
session.getTransaction().commit();
}catch(Exception e) {
e.printStackTrace();
session.getTransaction().rollback();
}finally {
HibernateUtils.closeSession(session);
}
//不能正确输出,抛出LazyInitializationException 异常,因为session已经关闭
//hibernate支持lazy策略只有在session打开状态下有效
System.out.println("group.name=" + group.getName());
集合上的lazy:建议使用extra,因为会发出智能sql。
session.beginTransaction();
//不会发出sql
Classes classes = (Classes)session.load(Classes.class, 1);
//会发出sql
System.out.println("classes.name=" + classes.getName());
//不会发出sql
Set students = classes.getStudents();
//会发出sql
for (Iterator iter=students.iterator(); iter.hasNext();) {
Student student = (Student)iter.next();
System.out.println("student.name=" + student.getName());
}
session.getTransaction().commit();
设置<class>标签上的lazy=false
session.beginTransaction();
//会发出sql
Classes classes = (Classes)session.load(Classes.class, 1);
//不会发出sql
System.out.println("classes.name=" + classes.getName());
//不会发出sql,class上的lazy不影响集合
Set students = classes.getStudents();
//会发出sql
for (Iterator iter=students.iterator(); iter.hasNext();) {
Student student = (Student)iter.next();
System.out.println("student.name=" + student.getName());
}
session.getTransaction().commit();
设置集合上的lazy=false,默认为true。
session.beginTransaction();
//不会发出sql
Classes classes = (Classes)session.load(Classes.class, 1);
//会发出sql,会发出两条sql分别加载Classes和Student
System.out.println("classes.name=" + classes.getName());
//不会发出sql
Set students = classes.getStudents();
//不会发出sql
for (Iterator iter=students.iterator(); iter.hasNext();) {
Student student = (Student)iter.next();
System.out.println("student.name=" + student.getName());
}
session.getTransaction().commit();
设置集合上的lazy=extra
1,跟lazy=true效果一样。
session.beginTransaction();
//不会发出sql
Classes classes = (Classes)session.load(Classes.class, 1);
//会发出sql
System.out.println("classes.name=" + classes.getName());
//不会发出sql
Set students = classes.getStudents();
//会发出sql
for (Iterator iter=students.iterator(); iter.hasNext();) {
Student student = (Student)iter.next();
System.out.println("student.name=" + student.getName());
}
session.getTransaction().commit();
2,发出智能sql
session.beginTransaction();
//不会发出sql
Classes classes = (Classes)session.load(Classes.class, 1);
//会发出sql
System.out.println("classes.name=" + classes.getName());
//不会发出sql
Set students = classes.getStudents();
//会发出sql,发出一条比较智能的sql,直接发出count()sql
System.out.println("student.count=" + students.size());
session.getTransaction().commit();
单端关联上的lazy:可以取值false,proxy,noproxy,默认proxy,noproxy采用字节码,需要增强工具支持。
单端关联上默认lazy属性:跟集合一样
session.beginTransaction();
//不会发出sql
User user = (User)session.load(User.class, 1);
//会发出sql
System.out.println("user.name=" + user.getName());
//不会发出sql
Group group = user.getGroup();
//会发出sql
System.out.println("group.name=" + group.getName());
session.getTransaction().commit();
单端关联上lazy=false:跟集合一样
session.beginTransaction();
//不会发出sql
User user = (User)session.load(User.class, 1);
//会发出sql,发出两条sql分别加载User和Group
System.out.println("user.name=" + user.getName());
//不会发出sql
Group group = user.getGroup();
//不会发出sql
System.out.println("group.name=" + group.getName());
session.getTransaction().commit();
class上lazy=fasle,单端关联上lazy=proxy
class上的lazy 不会影响到单端关联上的lazy。
session.beginTransaction();
//会发出sql
User user = (User)session.load(User.class, 1);
//不会发出sql
System.out.println("user.name=" + user.getName());
//不会发出sql
Group group = user.getGroup();
//会发出sql
System.out.println("group.name=" + group.getName());
session.getTransaction().commit();
发表评论
-
hibernate映射mysql text类型字段,报Data too long错误
2013-05-06 11:36 5669hibernate映射mysql text类型字段 ... -
Open_Session_In_View详解
2012-12-11 10:32 794在没有使用Spring提供的Open Session I ... -
Could not initialize proxy - the owning Session was closed
2012-12-11 09:35 6016Could not initialize proxy - ... -
hibernate学习笔记第22讲-抓取策略
2012-10-19 09:15 997抓取策略:抓取关联对象。 1单端代理的批量抓取: ... -
hibernate学习笔记第21讲-查询缓存
2012-10-19 09:15 946hibernate查询缓存 查询缓存是针对普通属 ... -
hibernate学习笔记第20讲-二级缓存
2012-10-18 08:27 914sessionFactory可以管理二级缓存。 Hib ... -
hibernate学习笔记第19讲-一级缓存
2012-10-18 08:27 742hibernate一级缓存 一级缓存很短和se ... -
hibernate学习笔记第18讲-悲观锁-乐观锁
2012-10-18 08:27 810Hibernate对悲观锁和乐观锁的支持,主要解决并发问 ... -
hibernate学习笔记第17讲-其他Set-List-Array-Map等映射
2012-10-18 08:27 8091,set映射:set是无序的 2,List映射,l ... -
hibernate学习笔记第16讲-复合主键映射
2012-10-18 08:26 982复合(联合)主键映射: 复合主键映射一般采用把主键相关 ... -
hibernate学习笔记第15讲-component映射
2012-10-17 09:08 778Component组件映射:对象模型细粒度划分,复用率提 ... -
hibernate学习笔记第14讲-继承映射
2012-10-17 09:08 858继承映射: 1,一个类继承树映射到一张表。一般采用第一 ... -
hibernate学习笔记第13讲-jdk动态代理和CGLib
2012-10-17 09:07 1506Jdk动态代理,CGLib字节码生成 如果目标对象实现 ... -
hibernate学习笔记第11讲-多对多关联映射many-to-many
2012-10-17 09:07 879单向映射 hibernate多对多关联映射( ... -
hibernate学习笔记第10讲-一对多关联映射one-to-many双向
2012-10-16 11:18 908hihernate一对多关联映射(双向Classes&l ... -
hibernate学习笔记第9讲-一对多关联映射one-to-many单向
2012-10-16 11:18 744一对多关联映射利用了多对一关联映射的原理。 ... -
hibernate学习笔记第8讲-session_flush-数据库隔离级别
2012-10-16 11:18 986Session flush: 默认在commit之前 ... -
hibernate学习笔记第7讲-一对一唯一外键关联映射one-to-one
2012-10-16 11:18 887Hibernate一对一唯一外键关联: 就是多对一的特 ... -
hibernate学习笔记第6讲-一对一主键关联映射one-to-one
2012-10-16 11:18 885Hibernate一对一主键关联: 1,单向主键关联: ... -
hibernate学习笔记第5讲-多对一关联映射many-to-one
2012-10-15 14:00 1022Hibernate 多对一映射: 关联映射 ...
相关推荐
**Hibernate学习笔记** Hibernate是一个强大的Java对象关系映射(ORM)框架,它简化了数据库操作,使得开发者可以更专注于业务逻辑而不是底层SQL语句。在本笔记中,我们将深入探讨Hibernate的核心概念、配置、实体...
Hibernate提供了第一级缓存(Session级别的)和第二级缓存(SessionFactory级别的)。第一级缓存默认开启,保存最近访问的对象;第二级缓存可选,常用于提高性能,但需注意并发问题。 八、关联映射 Hibernate支持一...
### 牛人的Spring学习笔记,非常适合初学者 #### 第一课:面向抽象编程 面向抽象编程是一种编程思想,强调在程序设计过程中通过定义抽象层来分离业务逻辑与具体实现细节。这种方式有助于提高软件的可维护性和扩展...
### Spring 2.5 学习笔记知识点梳理 #### 第一课:面向抽象编程 - **定义**:面向抽象编程是一种编程范式,强调通过抽象类或接口来设计程序结构,减少对具体实现的依赖。 - **优势**: - 提高了系统的可维护性与...
十、第一级缓存与第二级缓存 第一级缓存是Session级别的,每次操作的对象都会被放入缓存,提高读写速度。第二级缓存是SessionFactory级别的,可以跨Session共享,通常用于缓存不经常改变的数据。 以上是对...
{12}Oracle数据库}{151}{chapter.12} {12.1}术语}{151}{section.12.1} {12.2}登录数据库}{151}{section.12.2} {12.3}创建表格}{152}{section.12.3} {12.4}关于null值}{154}{section.12.4} {12.5}操作符与实例}...
【Spring学习笔记】 一、Spring概述 1.1 Spring框架的作用 Spring是一个开源的应用于企业级Java应用的全面框架,其主要目标是简化Java开发,提高代码可测试性,并促进良好的编程实践。它通过依赖注入(Dependency ...