hibernate基础04查询的多种方式

hibernate知识点

1 hibernate的查询方式

2 对象导航查询

3 hql查询

(1)查询所有

(2)条件查询

(3)排序查询

(4)分页查询

(5)投影查询

(6)聚集函数使用

4 qbc查询

(1)查询所有

(2)条件查询

(3)排序查询

(4)分页查询

(5)统计查询

(6)离线查询

5 hql多表查询

(1)mysql多表查询回顾

(2)hql多表查询

- 内连接、迫切内连接、左外连接、迫切左外连接、右外连接

6 hibernate的检索策略

(1)概念

- hibernate分成 :立即和延迟查询

- 延迟查询分成:类级别和关联级别延迟

(2)具体操作

 

Hibernate查询方式

1 对象导航查询

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

 

2 OID查询

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

 

3 HQL查询

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

 

4 QBC查询

(1)Criteria对象

 

5 本地sql查询

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

 

对象导航查询

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

 

2 代码

//根据cid=1客户,再查询这个客户里面所有联系人

Customer customer = session.get(Customer.class, 1);

//再查询这个客户里面所有联系人

//直接得到客户里面联系人的set集合

Set<LinkMan> linkman = customer.getLinkMans();

System.out.println(linkman.size());

 

OID查询

1 根据id查询记录

(1)调用session里面的get方法实现

Customer customer = session.get(Customer.class, 2);

 

HQL查询

1 hql:hibernate query language,hql语言和普通sql很相似,

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

 

2 常用的hql语句

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

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

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

 

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

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

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

 

查询所有

1 查询所有客户记录

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

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

 

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

//1 创建query对象

Query query = session.createQuery("from Customer");

//2 调用方法得到结果

List<Customer> list = query.list();

 

条件查询

1 hql条件查询语句写法:

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

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

 

2 代码

//1 创建query对象

Query query = session.createQuery("from Customer c where c.cid=? and c.custName=?");

//2 设置条件值

// 向?里面设置值 setParameter方法两个参数

// 第一个参数:int类型是?位置,?位置从0开始

// 第二个参数:具体参数值

query.setParameter(0, 1);

query.setParameter(1, "百度");

List<Customer> list = query.list();

 

模糊查询

//1 创建query对象

Query query = session.createQuery("from Customer c where c.custName like ?");

//2 设置?的值

query.setParameter(0, "%浪%");

//3 调用方法得到结果

List<Customer> list = query.list();

 

排序查询

1 hql排序语句写法

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

//1 创建query对象

Query query = session.createQuery("from Customer order by cid desc");

//2 调用方法得到结果

List<Customer> list = query.list();

 

分页查询

1 mysql实现分页

(1)使用关键字 limit实现

  select * from t_customer limit 0,3;

2 在hql中实现分页

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

Query query = session.createQuery("from Customer");

// 设置分页数据

//1 设置开始位置

query.setFirstResult(0);

/.2 设置每页记录数

query.setMaxResults(3);

List<Customer> list = query.list();

 

投影查询

1 投影查询:查询不是所有字段值,而是部分字段的值

 

2 投影查询hql语句写法:

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

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

 

3 具体实现

//1 创建query对象

Query query = session.createQuery("select custName from Customer");

//2 调用方法得到结果

List<Object> list = query.list();

 

聚集函数使用

1 常用的聚集函数

(1)count、sum、avg、max、min

 

2 hql聚集函数语句写法

(1)查询表记录数

- select count(*) from 实体类名称

 

Query query = session.createQuery("select count(*) from Customer");

//2 调用方法得到结果

//query对象里面有方法,直接返回对象形式

Object obj = query.uniqueResult();

//返回int类型

//首先把object变成long类型,再变成int类型

Long lobj = (Long) obj;

int count = lobj.intValue();

System.out.println(count);

注:若直接把object对象转为int对象,会产生ClassCastException类型转换异常

 

QBC查询

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

 

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

 

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

 

查询所有

1 创建Criteria对象

2 调用方法得到结果

//1 创建对象

Criteria criteria = session.createCriteria(Customer.class);

//2 调用方法得到结果

List<Customer> list = criteria.list();

 

条件查询

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

//1 创建对象

Criteria criteria = session.createCriteria(Customer.class);

//2 使用Criteria对象里面的方法设置条件值

// 首先使用add方法,表示设置条件值

// 在add方法里面使用类的方法实现条件设置

//criteria.add(Restrictions.eq("cid", 1));

//criteria.add(Restrictions.eq("custName", "百度"));

criteria.add(Restrictions.like("custName", "%百%"));

List<Customer> list = criteria.list()

 

排序查询

//1 创建对象

Criteria criteria = session.createCriteria(Customer.class);

//2 设置对哪个属性进行排序,设置排序规则

criteria.addOrder(Order.desc("cid"));

//3 调用方法得到结果

List<Customer> list = criteria.list();

 

分页查询

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

//1 创建对象

Criteria criteria = session.createCriteria(Customer.class);

//2 设置分页数据

//2.1 设置开始位置

criteria.setFirstResult(0);

//2.2 每页显示记录数

criteria.setMaxResults(3);

 

统计查询

//1 创建对象

Criteria criteria = session.createCriteria(Customer.class);

//2 设置操作

criteria.setProjection(Projections.rowCount());

//3 调用方法得到结果

Object obj = criteria.uniqueResult();

Long lobj = (Long) obj;

int count = lobj.intValue();

 

离线查询

1 servlet调用service,service调用dao

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

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

//1 创建对象

//Criteria criteria = session.createCriteria(Customer.class);

DetachedCriteria detachedCriteria = DetachedCriteria.forClass(Customer.class);

//2 最终执行时候才需要到session

Criteria criteria = detachedCriteria.getExecutableCriteria(session);

List<Customer> list = criteria.list();

 

HQL多表查询

Mysql里面多表查询

1 内连接(只有表有关联的数据才显示)

 

2 左外连接(左表所有数据右表关联数据)

 

3 右外连接(有表所有数据左表关联数据)

 

 

HQL实现多表查询

Hql多表查询

(1)内连接

(2)左外连接

(3)右外连接

(4)迫切内连接

(5)迫切左外连接

HQL内连接

1 内连接查询hql语句写法:以客户和联系人为例

(1)from  Customer  c  inner  join  c.setLinkMan

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

//1 创建query对象

Query query = session.createQuery("from Customer c inner join c.setLinkMan");

List list = query.list();

 

2 演示迫切内连接

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

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

(3)hql语句写法

from Customer c inner join fetch c.linkMans;

 

 

HQL左外连接

1 左外连接hql语句:

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

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

 

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

 

 

1 右外连接hql语句:

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

 

Hibernate检索策略

检索策略的概念

1 hibernate检索策略分为两类:

(1)立即查询:根据id查询,调用get方法,一调用get方法马上发送语句查询数据库

//根据cid=1客户,再查询这个客户里面所有联系人

Customer customer = session.get(Customer.class, 1);

//再查询这个客户里面所有联系人

//直接得到客户里面联系人的set集合

//得到set集合,没有发送语句

Set<LinkMan> linkman = customer.getLinkMans();

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

//根据cid=1客户

/*

* 1 调用load方法之后,不会马上发送sql语句

* (1)返回对象里面只有 id值

* 2 得到对象里面不是id的其他值时候才会发送语句

* */

Customer customer = session.load(Customer.class, 2);

System.out.println(customer.getCid());

System.out.println(customer.getCustName());

 

2 延迟查询分成两类:

(1)类级别延迟:根据id查询返回实体类对象,调用load方法不会马上发送语句

(2)关联级别延迟:

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

 

关联级别延迟操作

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

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

 

2 在set标签上使用属性

(1)fetch:值select(默认)

(2)lazy:值

- true:延迟(默认)执行代码时发送语句

 

- false: 没有延迟 调用get之后,发送两条sql语句

 

- extra:极其延迟 极其懒惰,要什么值给什么值

 

批量抓取

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

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

//查询所有客户

Criteria criteria = session.createCriteria(Customer.class);

List<Customer> list = criteria.list();

//得到每个客户里面所有的联系人

for (Customer customer : list) {

System.out.println(customer.getCid()+"::"+customer.getCustName());

//每个客户里面所有的联系人

Set<LinkMan> setLinkMan = customer.getLinkMans();

for (LinkMan linkMan : setLinkMan) {

System.out.println(linkMan.getLkm_id()+"::"+linkMan.getLkm_name());

}

}

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

 

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

<set name="linkMans" cascade="save-update,delete" inverse="true"

fetch="select" lazy="extra" batch-size="10">

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值