hibernate5--4.检索方式及策略

    xiaoxiao2021-03-25  54

    1       Hibernate检索方式

    1 对象导航查询

           根据id查询某个客户,再查询这个客户里面所有的联系人

     

    2 OID查询

           根据id查询某一条记录,返回对象

     

    3 HQL查询

           Query对象,写hql语句实现查询

     

    4 QBC查询

           Criteria对象

     

    5 本地sql查询

           SQLQuery对象,使用普通sql实现查询

     

     

    1.1  对象导航查询

    1 查询某个客户里面所有联系人过程,使用对象导航实现,set集合

           一对多查询

    2 代码

     

    1.2  OID查询

           根据id查询记录,调用session里面的get方法实现

    1.3  HQL查询

    1 hql:

           hibernatequery language,hibernate提供一种查询语言,hql语言和普通sql很相似,

           区别:普通sql操作数据库表和字段,hql操作实体类和属性

     

    2 常用的hql语句

    1)查询所有: from实体类名称

    2)条件查询: from实体类名称 where属性名称=?

                  模糊查询  like

    3)排序查询: from实体类名称 order by实体类属性名称 asc/desc

    (4)分页查询:没有limit

    (5)投影查询:select 实体类属性名称1, 实体类属性名称2  from 实体类名称

    (6)聚集函数:select count(*) from 实体类名称

     

    Sql:

     

    3 使用hql查询操作时候,使用Query对象

    (1)创建Query对象,写hql语句

    (2)调用query对象里面的方法得到结果

    1.3.1   查询所有

    1 查询所有客户记录

    (1)创建Query对象,写hql语句

    (2)调用query对象里面的方法得到结果

     

    2 查询所有: from 实体类名称

     

    1.3.2   条件查询

    1 hql条件查询语句写法:

    (1) from  实体类名称 where 实体类属性名称=? and实体类属性名称=?

    from  实体类名称 where 实体类属性名称 like ?

    2 代码

    模糊查询

    1.3.3   排序查询

    1 hql排序语句写法

    (1)from 实体类名称 order by 实体类属性名称 asc/desc

      

    1.3.4   分页查询

    1 mysql实现分页

    (1)使用关键字 limit实现

     

    2 在hql中实现分页

    (1)在hql操作中,在语句里面不能写limit,hibernate的Query对象封装两个方法实现分页操作

      

    1.3.5   投影查询

    1 投影查询

           查询不是所有字段值,而是部分字段的值

     

    2 投影查询hql语句写法:

    (1)select 实体类属性名称1, 实体类属性名称2  from 实体类名称

    (2)select 后面不能写 * ,不支持的

     

    3 具体实现

     

    1.3.6   聚集函数使用

    1 常用的聚集函数

           count、sum、avg、max、min

     

    2 hql聚集函数语句写法

           查询表记录数:select count(*) from 实体类名称

     

    1.4  QBC查询

    1 使用hql查询需要写hql语句实现,但是使用qbc时候,不需要写语句了,使用方法实现

     

    2 使用qbc时候,操作实体类和属性

     

    3 使用qbc,使用Criteria对象实现 

    1.4.1   查询所有

    1 创建Criteria对象

    2 调用方法得到结果

     

    1.4.2   条件查询add()

           没有语句,使用封装的方法实现

    模糊查询:

    1.4.3   排序查询addOrder()

    Order的方法:

     

    1.4.4   分页查询

           开始位置计算公式: (当前页-1)*每页记录数

     

    1.4.5   统计查询

     

    1.4.6   离线查询

           servlet调用service,service调用dao

    (1)在dao里面对数据库crud操作

    (2)在dao里面使用hibernate框架,使用hibernate框架时候,调用session里面的方法实现功能

     

    (3)在后面ssh练习中具体应用

     

    1.5  HQL多表查询

    1.5.1   Mysql里面多表查询

    1 内连接

     

    2 左外连接

     

    3 右外连接

    1.5.2   HQL实现多表查询

    Hql多表查询

    (1)内连接

    (2)左外连接

    (3)右外连接

    (4)迫切内连接

    (5)迫切左外连接

     

    1.5.3   HQL内连接

    1 内连接查询

    hql语句写法:以客户和联系人为例

           from  Customer c  inner  join  c.setLinkMan

    返回list,list里面每部分是数组形式

     

    2 演示迫切内连接

    (1)迫切内连接和内连接底层实现一样的

    (2)区别:使用内连接返回list中每部分是数组,迫切内连接返回list每部分是对象

    (3)hql语句写法

    - from  Customer  c inner  join  fetch c.setLinkMan

     

     

    1.5.4   HQL左外连接

    1 左外连接hql语句:

    (1)from  Customer c  left  outer join  c.setLinkMan

    (2)迫切左外连接from  Customer  c left  outer  join  fetch c.setLinkMan

     

    2 左外连接返回list中每部分是数组,迫切左外连接返回list每部分是对象

     

    1 右外连接hql语句:

    (1)from  Customer c  right  outer join  c.setLinkMan

    2       Hibernate检索策略

    2.1  检索策略的概念

           hibernate检索策略分为两类:

    2.1.1   立即查询:

    根据id查询,调用get方法,一调用get方法马上发送语句查询数据库

     

    2.1.2   延迟查询:

           根据id查询,还有load方法,调用load方法不会马上发送语句查询数据,只有得到对象里面的值时候才会发送语句查询数据库

     

           延迟查询分成两类:类级别延迟,关联级别延迟

    2.1.2.1       类级别延迟:

    根据id查询返回实体类对象,调用load方法不会马上发送语句

     

    2.1.2.2       关联级别延迟—系统默认:

    - 查询某个客户,再查询这个客户的所有联系人,查询客户的所有联系人的过程是否需要延迟,这个过程称为关联级别延迟

    2.2  关联级别延迟操作—自定义

     

    1 在映射文件中进行配置实现

    (1)根据客户得到所有的联系人,在客户映射文件中配置

    2 在set标签上使用属性

    (1)fetch:值select(默认)

    (2)lazy:值

    - true:延迟(默认)

    - false:不延迟

    - extra:极其延迟

     

    2.3  批量抓取

    1 查询所有的客户,返回list集合,遍历list集合,得到每个客户,得到每个客户的所有联系人

    稍加修改:

     

    (1)上面操作代码,发送多条sql语句

     

    2 在客户的映射文件中,set标签配置

    (1)batch-size值,值越大发送语句越少,

    源代码文件:http://download.csdn.net/detail/qq_26553781/9778969

    转载请注明原文地址: https://ju.6miu.com/read-38491.html

    最新回复(0)