分享知识-快乐自己:Hibernate中的 quert.list() 与 quert.iterate() 方法区别
区别如下:
quert.list() :
1):每次都是通过一条语句直接操作数据库取出所有的数据返回(并且将对象存入hibernate缓存中);
2):不会从一二级缓存中查询数据;
3):之执行一条SQL语句,查询所有。
quert.iterate():
1):iterator首先通过一条语句取出所有数据的id,然后通过id在hibernate的一级缓存中查找是否存在该对象,
2):如果存在则直接取出,如果没有则再次发出一条sql语句通过id取得对象(并且加入到缓存中),
3):这样如果所有的id在缓存中都没有的话就会出现n+1条sql语句的问题。
这样大家可能会想,同样的查询条件,第一次先list,第二次再iterate,就可以使用到缓存了。
实际上这是很难的,因为你无法判断什么时候是第一次,而且每次查询的条件通常是不一样的,假如数据库里面有100条记录,id从1到100,
第一次list的时候出了前50个id,第二次iterate的时候却查询到30至70号id,那么30-50是从缓存里面取的,51到70是从数据库取的,共发送1+20条sql
相关测试关键代码:
/****
* list查询数据:观察产生的SQL语句条数(共 N+1+1 条SQL)
*/
@Test
public void listUser()
{
//iterate:执行(N+1)条SQL语句:一条查询所有的ID,然后根据OID查询详细信息。
// 首先会经过缓存,缓存中没有匹配信息的话,则走数据库执行SQL语句查询(并添加到缓存中)
Iterator<User> from_user1 = session.createQuery("from User").iterate();
while (from_user1.hasNext())
{
System.out.println(from_user1.next());
}
System.err.println("*************\n");
//list:执行一条SQL语句:只往缓存中存放,无法读取一二级缓存
List<User> from_user = session.createQuery("from User").list();
for (User temp:from_user)
{
System.out.println(temp);
}
}
/****
* iterate查询数据:观察产生的SQL语句条数(共2条SQL)
*/
@Test
public void iterateUser()
{
//list:执行一条SQL语句:只往缓存中存放,无法读取一二级缓存
List<User> from_user = session.createQuery("from User").list();
for (User temp:from_user)
{
System.out.println(temp);
}
System.err.println("*************");
//iterate:执行(N+1)条SQL语句:一条查询所有的ID,然后根据OID查询详细信息。
// 首先会经过缓存,缓存中没有匹配信息的话,则走数据库执行SQL语句查询(并添加到缓存中)
Iterator<User> from_user1 = session.createQuery("from User").iterate();
while (from_user1.hasNext())
{
System.out.println(from_user1.next());
}
}
分享知识-快乐自己:Hibernate中的 quert.list() 与 quert.iterate() 方法区别的更多相关文章
- Jquery中的has、find、filter方法区别
find方法 find返回的是匹配结果集,作用于后代$(‘li’).find(‘.a’).css(‘background-color’, ‘red’);在li下面查找元素是否有class=a的元素,返 ...
- Hibernate中load与get,update与merge方法的区别
1.load()与get()的区别: (1)load()读取 User user = (User)session.load(User.class, userId); (2)get()读取 User u ...
- 分享知识-快乐自己:MYSQL之內链接 左链接 右链接 区别
MYSQL中可以通过内外键链接,将有关系的表中数据合并到一起进行条件筛选: 首先创建两个新表,数据如下: student 表数据: score 表数据: 可以看到students表中stu_id为16 ...
- hibernate 中的 lazy=”proxy” 和 lazy=”no-proxy” 的区别
网上找到个描述的很精妙的例子 Child <- many-to-one ->Parent class Child { private ...
- JavaScript中正则表达式test()、exec()、match() 方法区别
1.test test 返回 Boolean,查找对应的字符串中是否存在模式.var str = "1a1b1c";var reg = new RegExp("1.&qu ...
- 分享知识-快乐自己:Hibernate各种查询操作
Hibernate各种查询操作(一) 测试数据库如下: t_sort表: t_good表: 一.对象导航方式查询 查询所有食品类下面 ...
- Hibernate中事务的隔离级别设置
Hibernate中事务的隔离级别,如下方法分别为1/2/4/8. 在Hibernate配置文件中设置,设置代码如下
- hibernate中session的获取使用以及其他注意事项
hibernate中session的获取使用以及其他注意事项 前言:工作时,在同时使用Hibernate的getSession().getHibernateTemplate()获取Session后进行 ...
- (七)Hibernate中使用JDBC
在hibernate中获取connection数据库连接有两种方法:(操作数据库常用这种方法) 1. session.doReturningWork 返回一个对象,适用于查询方法 2. sessi ...
随机推荐
- Hadoop1.2.1 全然分布式集群搭建实操笔记
前期准备工作: 1.改动Linux主机名:/etc/hostname ubuntu系统:vi /etc/hostname ...
- 【Excle数据透视】二维数据如何创建数据透视表
二维数据在创建数据透视表的时候,可能会给你带来一些麻烦,没法创建,会丢失维度,那怎么办呢? 解决办法:使用数据透视表和数据透视图向导即可创建 具体操作如下: 按下[Alt+D+P],出现如下界面 选择 ...
- 美柚“姨妈假”上头条,App事件营销怎么做
近期,微博上有关"姨妈假"的话题异常火爆,事件源于厦门互联网企业美柚所推出的一项"奇葩福利"------女员工可向公司请姨妈假.此事经媒体报道.微博爆料 ...
- 在VS2013中打开Nuget
1.工具→NuGet程序包管理器→程序包管理控制台 2.没有的话,就去 工具→扩展和更新 搜索nuget
- Hadoop2.2.0-64位编译
本作品由Man_华创作,采用知识共享署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可.基于http://www.cnblogs.com/manhua/上的作品创作. 实验环境:Ubunt ...
- JQuery EasyUI DataGrid动态合并单元格
/** * EasyUI DataGrid根据字段动态合并单元格 * @param fldList 要合并table的id * @param fldList ...
- SQL Server排序的时候使null值排在最后
首先建一个表插入一些测试数据 create table UserInfo ( UserInfoID int not null identity(1,1) primary key, Use ...
- MySQL-[Err] 1055 - Expression #1
© 版权声明:本文为博主原创文章,转载请注明出处 问题描述:在MySQL数据库下,执行SQL插入语句报错.错误信息如下: 错误原因:在MySQL5.7之后,sql_mode中默认存在ONLY_FULL ...
- 修复open-ssl漏洞,升级open-ssl版本
升级openssl环境至openssl-1.0.1g 1.查看源版本 [root@zj ~]# openssl version -a OpenSSL 0.9.8e-fips-rhel5 01 Jul ...
- C++刷题——2736: 指针练习--输出最大值
Description 採用指针法,输出10个整型数中的最大值和最小值 Input 10个整数 Output 最大值和最小值 Sample Input 2 6 3 8 1 5 7 0 4 9 Samp ...