我是从b站视频上学习的hibernate框架,其中有很多和当前版本不符合之处,我在笔记中进行了修改
以下是b站视频地址:
https://www.bilibili.com/video/av14626440

 
Hibernate查询方式
1 对象导航查询
1)根据id来查询出某个客户,再查询这个客户里面的联系人
2 oid查询
1)根据id查询某一条记录,返回对象(利用session里面的get方法)
3 hql查询
1)Query对象,写hql语句
 
*查询所有 : from  实体类名称
*条件查询:(支持别名)(注意:hibernate3.5版本后不支持'?'改为JPA规范 '?'+数字)
                “from  实体类名称 where 实体类属性名称 = ?0 and 实体类属性名称 = ?1”
                “from  实体类名称 as c  where c.实体类属性名称 = ?0 and  c.实体类属性名称 = ?1"
                             " from  实体类名称 where 实体类属性名称 like ?0"
模糊查询:
 
*排序查询:from 实体类名称 ORDER BY 实体类属性名称 ASC/DESC(升序/降序)
*分页查询:
mysql中使用limit关键字进行分页,但是hql语句中并没有limit这个关键字,但是Query对象封装了两个方法来实现分页
*投影查询:查询部分字段的记录
1)select 实体类属性1 ,实体类属性2 from 实体类名称
2)select后面不能加*号,不支持
*聚集函数使用:
常用的聚集函数count,sum,avg,max,min
以count为例演示
 
 
注意:得到的object不能直接转化成int类型,要先转换为long类型在转换为int类型
 
 
4 qbc查询
1)cirtria对象(已过时)
5 本地sql查询
1)SQLQuey对象,使用sql进行查询
 
 
 
*HQL多表查询
mysql里面的多表查询
1)内连接查询(内链接查询出来的是两张表的关联数据)
2)左外连接(左外连接会显示左边表的所有数据和右边表的关联数据)
3)右外连接(右外连接会显示左边表的关联数据和右边表的说所有数据)
 
 
HQL实现多表查询
1)内连接
form Customer c inner join c.setLinkman
返回的list里面每部分是数组形式
 
2)迫切内连接(使用fetch关键字)
迫切内连接和内连接底层实现是一样的
区别:使用内连接返回的list里面是数组,而迫切内连接返回的list里面是对象
form Customer c inner join  fetch  c.setLinkMan
 
3)左外连接
from customer c left outer join c.setLinkMan
 
4)迫切左外连接
from customer c left outer join fetch c.setLinkMan
 
3)右外连接
from customer c right outer join c.setLinkMan
 
*hibernate 检索策略
 
.检索策略的概念
1 hibernate检索策略分为两类
   1)立即查询:根据id查询,调用get方法,一调用get方法就马上发送语句来查询数据库
   2)延迟查询:根据id查询,调用load方法,调用load方法不会马上发送语句查询数据库,只有得到对象里面的值的时候,才会去发送语句查询数据库
 
2 延迟查询分成两类
1)类级别的延迟:根据id查询返回实体类对象,调用load方法不会马上发送语句
2)关联级别的延迟:查询出某个客户,在查询这个客户的联系人,就是查询客户的所有联系人的的过程是否需要延迟,这个过程就是关联级别的延迟
 
 
.关联级别延迟操作
1 在映射文件中进行配置来实现
1)根据客户得到所有的联系人,在客户映射文件中配置
 
 
2 在set属性中进行配置
     1)fetch: 一般默认值 select
     2)lazy:
        -true :  延迟(默认)
        -flase : 不延迟
        -extra :极其延迟
 
*hibernate 批量抓取
1 要查询所有客户,返回list集合,遍历list集合,得到每个客户,得到每个客户的所有联系人
        1)完成上面需求,会发送多条sql语句,造成效率低下
        2)hibernate提供了批量抓取的方式来提高效率
2 在客户的映射文件中进行set标签配置batch-size,值越大发送的语句越少,和你的数据量有关
 
 
 
 

Hibernate学习笔记(四)的更多相关文章

  1. Hibernate学习笔记四 查询

    HQL语法 1.基本语法 String hql = " from com.yyb.domain.Customer ";//完整写法 String hql2 = " fro ...

  2. Hibernate学习笔记四:事务管理

    转载请注明原文地址:http://www.cnblogs.com/ygj0930/p/6768298.html  一:需要事务的Session操作 Session操作中,查询类操作是不需要事务就能生效 ...

  3. Hibernate学习笔记四

    1 整合log4j(了解) l slf4j 核心jar  : slf4j-api-1.6.1.jar .slf4j是日志框架,将其他优秀的日志第三方进行整合. l 整合导入jar包 log4j 核心包 ...

  4. Hibernate学习笔记(二)

    2016/4/22 23:19:44 Hibernate学习笔记(二) 1.1 Hibernate的持久化类状态 1.1.1 Hibernate的持久化类状态 持久化:就是一个实体类与数据库表建立了映 ...

  5. Hibernate学习笔记(一)

    2016/4/18 19:58:58 Hibernate学习笔记(一) 1.Hibernate框架的概述: 就是一个持久层的ORM框架. ORM:对象关系映射.将Java中实体对象与关系型数据库中表建 ...

  6. Hibernate 学习笔记一

    Hibernate 学习笔记一 今天学习了hibernate的一点入门知识,主要是配置domain对象和表的关系映射,hibernate的一些常用的配置,以及对应的一个向数据库插入数据的小例子.期间碰 ...

  7. C#可扩展编程之MEF学习笔记(四):见证奇迹的时刻

    前面三篇讲了MEF的基础和基本到导入导出方法,下面就是见证MEF真正魅力所在的时刻.如果没有看过前面的文章,请到我的博客首页查看. 前面我们都是在一个项目中写了一个类来测试的,但实际开发中,我们往往要 ...

  8. IOS学习笔记(四)之UITextField和UITextView控件学习

    IOS学习笔记(四)之UITextField和UITextView控件学习(博客地址:http://blog.csdn.net/developer_jiangqq) Author:hmjiangqq ...

  9. Hibernate学习笔记-Hibernate HQL查询

    Session是持久层操作的基础,相当于JDBC中的Connection,通过Session会话来保存.更新.查找数据.session是Hibernate运作的中心,对象的生命周期.事务的管理.数据库 ...

  10. java之jvm学习笔记四(安全管理器)

    java之jvm学习笔记四(安全管理器) 前面已经简述了java的安全模型的两个组成部分(类装载器,class文件校验器),接下来学习的是java安全模型的另外一个重要组成部分安全管理器. 安全管理器 ...

随机推荐

  1. SqlServer2005使用top 100 PERCENT 无法排序的问题

    由于公司提供的分页控件需要我使用top子句,而且有必要将查询到的记录全部取出,确发现不能排序,sql语句如下: SELECT TOP 15 * FROM( SELECT TOP (100) PERCE ...

  2. 深入Docker 存储驱动 (转)

    参考: http://static.dockerone.com/ppt/filedriver.html#28

  3. scriptPubKey and scriptSig

    First of all two matching scripts are used in two different transactions, one that transfers funds t ...

  4. Spring AOP源码解析——专治你不会看源码的坏毛病!

    昨天有个大牛说我啰嗦,眼光比较细碎,看不到重点.太他爷爷的有道理了!要说看人品,还是女孩子强一些. 原来记得看到一个男孩子的抱怨,说怎么两人刚刚开始在一起,女孩子在心里就已经和他过完了一辈子.哥哥们, ...

  5. JavaScript Html2canvas 生成高清图片(移动端模糊问题)

    最近在做一个移动端的项目,简单记录一下该功能. 需求是这样的: 将带有二维码和一些介绍信息 动态生成一张图片 比如说是 生成这样的图片,文字.主图.价格.二维码都是不固定的. 对于这个需求,看见微信上 ...

  6. NET实现谷歌OCR的使用记录(CLOUD VISION API)

    1)购买VPS 2)配置一VPN 建议使用 cisco anycounect  |   ***会连接失败(切记,祭奠浪费的一天)大神可以帮我看下是什么问题 3)进入https://cloud.goog ...

  7. Dubbo 源代码分析八:再说 Provider 线程池被 EXHAUSTED

    转自:http://manzhizhen.iteye.com/blog/2391177 在上回<Dubbo源代码实现六>中我们已经了解到,对于Dubbo集群中的Provider角色,有IO ...

  8. C指针复制字符串从一个数组到另一个数组

    #include <stdio.h> void  copyString (char  *to, char  *from) {      while ( *from ) // from指针遇 ...

  9. [题解] cogs 2240 架设电话线路

    http://cogs.pro:8080/cogs/problem/problem.php?pid=2240 与洛谷P2885几乎一致,https://www.luogu.org/problemnew ...

  10. MySQL数据库文件

    MySQL数据库文件 本文档从MySQL数据库和存储引擎层面介绍各种类型的文件. 参数文件(my.cnf) 错误日志(error log) 二进制日志文件(binary log) 慢查询日志(slow ...