分享web开发知识

注册/登录|最近发布|今日推荐

主页 IT知识网页技术软件开发前端开发代码编程运营维护技术分享教程案例
当前位置:首页 > 前端开发

hibernate学习(4)

发布时间:2023-09-06 02:21责任编辑:赖小花关键词:暂无标签

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.getSetLinkMan(); ???????????????????????System.out.println(linkman.size());

OID查询

1 根据id查询记录

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

//根据cid=1客户,再查询这个客户里面所有联系人Customer customer = session.get(Customer.class, 1);

HQL查询

1 hql:hibernate query language,hibernate提供一种查询语言,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 代码

使用的方法是:

query.setParameter(arg0, arg1);
// 1 创建query对象 ???????????// select * from t_customer where cid=? and custName=? ???????????Query query = session.createQuery("from Customer where cid=? and custName=?"); ???????????// 2 设置条件值 ???????????// 向?里面设置值 ???????????// setParameter方法两个参数 ???????????// 第一个参数:int类型是?位置,?位置从0开始 ???????????// 第二个参数:具体参数值 ???????????// 设置第一个参数值?和preparedstatement不一样的是,它是从0开始的 ???????????query.setParameter(0, 4); ???????????// 设置第二个?值 ???????????query.setParameter(1, "baidu"); ???????????// 3 调用方法的到结果 ???????????List<Customer> list = query.list(); ???????????

模糊查询

// 1 创建query对象 ???????????????// select * from t_customer where cid=? and custName=? ???????????????Query query = session.createQuery("from Customer where cid=? and custName like ?"); ???????????????????????????????//2 设置?的值 ???????????????//_na %na% ???????????????query.setParameter(0, 2); ???????????????query.setParameter(1, "%in%"); ???????????????????????????????//3 调用方法得到结果 ???????????????List<Customer> list = query.list();

hibernate底层sql代码

Hibernate: ????select ???????customer0_.cid as cid1_0_, ???????customer0_.custName as custName2_0_, ???????customer0_.custLevel as custLeve3_0_, ???????customer0_.custSource as custSour4_0_, ???????customer0_.custPhone as custPhon5_0_, ???????customer0_.custMobile as custMobi6_0_ ????from ???????t_customer customer0_ ????where ???????customer0_.cid=? ????????and ( ???????????customer0_.custName like ? ???????)

排序查询

1 hql排序语句写法

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

// 1 创建query对象 ???????????Query query = session.createQuery("from Customer order by cid asc"); ???????????????????????//2 调用方法得到结果 ???????????List<Customer> list = query.list(); ???????????

分页查询

1 mysql实现分页

(1)使用关键字limit实现

select * from t_customer limit 0,2;

第一个参数是开始位置,第二个参数是每页显示几条记录。

2 在hql中实现分页

(1)在hql操作中,在语句里面不能写limit(这是MySQL特有,Hibernate不认识),hibernate的Query对象封装两个方法实现分页操作。

// 1 创建query对象 ???????????????Query query = session.createQuery("from Customer"); ???????????????????????????????// 2 设置分页数据 ???????????????// 2.1 设置开始位置 ???????????????query.setFirstResult(0); ???????????????// 2.2 设置每页记录数 ???????????????query.setMaxResults(2); ???????????????????????????????// 3 调用方法得到结果 ???????????????List<Customer> list = query.list(); ???????????????

投影查询

1 投影查询

聚集函数使用 

hibernate学习(4)

原文地址:https://www.cnblogs.com/liaoxiaolao/p/9926380.html

知识推荐

我的编程学习网——分享web前端后端开发技术知识。 垃圾信息处理邮箱 tousu563@163.com 网站地图
icp备案号 闽ICP备2023006418号-8 不良信息举报平台 互联网安全管理备案 Copyright 2023 www.wodecom.cn All Rights Reserved