我是从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. iptables规则的关系

    iptables规则的关系,是自上而下进行过虑的.所以添加规则时,要通过文件进行添加,这样的话,可以控制其顺序. A机器: [root@www ~]# netstat -an | grep 6100 ...

  2. 开发笔记 - 解决font-awesome等图标在浏览器中的兼容问题

    今天在写前端页面的时候,觉得font-awesome简单实用就上手试了一下,因为font-awesome图标库甚为强大,我就在其css上多做了一些尝试,这一尝试发现了一个致命的问题,当我对i标签进行统 ...

  3. docker新手入门(基本命令以及介绍)

    Docker 的核心内容 镜像 (Image) 容器 (Container) 仓库 (Repository) Registry 用来保存用户构建的镜像 docker的开始使用: 1. docker  ...

  4. JavaScript-基础类型和运算符

    JavaScript-基础类型和运算符 P02.稍微了解 1.js代码需要编写到script标签中 <script type="text/javascript"> 此处 ...

  5. TensorFlow低阶API(四)—— 图和会话

    简介 TensorFlow使用数据流图将计算表示为独立的指令之间的依赖关系.这可生成低级别的编程模型,在该模型中,您首先定义数据流图,然后创建TensorFlow会话,以便在一组本地和远程设备上运行图 ...

  6. Mac 创建软链接

    ln -s /Volumes/dzqExt/source/wukongqipai/wukongqipai/ccclient/Classes/ ./frameworks/runtime-src/     ...

  7. C++ Simple Message/Logging Class

    在 Qt的源码与Protobuf 的代码中,看到相同的简单消息(日志)输出的类实现,基本思路是使用宏定义,重载临时类对象,调用类方法或者通过析构函数自动调用输出方法,实现消息输出.这里以 Protob ...

  8. linux 服务器 php vue项目部署流程总结

    服务器配置 购买阿里云服务器 (选择ubuntu 16系统 / 内存2G以上) 安全策略, 入规则: 添加端口 20,21,22, 80, 443, 3306, 8080, 安装宝塔 wget -O ...

  9. pycharm的快捷键以及常用设置

    1.编辑(Editing) Ctrl + Space 基本的代码完成(类.方法.属性) Ctrl + Alt + Space 快速导入任意类 Ctrl + Shift + Enter 语句完成 Ctr ...

  10. You must specify a valid lifecycle phase or a goal in the format <plugin-prefix>:<goal> or <plugin-group-id>:<plugin-artifact-id>[:<plugin-version>]:<goal>. Available lifecycle phases are: validate, i

    [ERROR] Unknown lifecycle phase "mvn". You must specify a valid lifecycle phase or a goal ...