HQL多表查询
------------------siwuxie095
HQL 多表查询
以客户和联系人为例(一对多)
1、内连接
(1)hql 语句写法
from Customer c inner join c.linkManSet
(2)具体实现



|
/* * (1) 创建 Query 对象 * * 调用 session 的 createQuery() 方法,参数是 hql * 语句,返回值是 Query 类型,创建以接收 */ Query query=session.createQuery("from Customer c inner join c.linkManSet"); /* * (2) 调用方法得到结果 * * 调用 query 的 list() 方法,返回值是 List 类型, * 创建以接收 * * 注意:此时返回的 List 的每部分都是一个数组,而 * 不是 Customer 对象或 LinkMan 对象,所以指定泛 * 型为 Object[] */ List<Object[]> list=query.list(); for (Object[] obj : list) { Customer customer=(Customer) obj[0]; LinkMan linkMan=(LinkMan) obj[1]; System.out.println(customer.getCustName()+"-"+linkMan.getLkmName()); } |
(3)返回的 List 中,每部分都是一个数组
2、迫切内连接
(1)迫切内连接 和 内连接 的底层实现(即 sql 语句)都一样
(2)区别:
1)内连接返回的 List 中,每部分都是一个数组
2)迫切内连接返回的 List 中,每部分都是一个对象
(3)hql 语句写法
from Customer c inner join fetch c.linkManSet
(4)具体实现



|
/* * (1) 创建 Query 对象 * * 调用 session 的 createQuery() 方法,参数是 hql * 语句,返回值是 Query 类型,创建以接收 */ Query query=session.createQuery("from Customer c inner join fetch c.linkManSet"); /* * (2) 调用方法得到结果 * * 调用 query 的 list() 方法,返回值是 List 类型, * 创建以接收 * * 注意:此时返回的 List 的每部分都是一个 Customer * 对象 */ List<Customer> list=query.list(); for (Customer cust : list) { System.out.println(cust.getCustName()+"-"+cust.getLinkManSet().size()); } |
3、左外连接
(1)hql 语句写法
from Customer c left outer join c.linkManSet
(2)左外连接返回的 List 中,每部分都是一个数组
4、迫切左外连接
(1)hql 语句写法
from Customer c left outer join fetch c.linkManSet
(2)迫切左外连接返回的 List 中,每部分都是一个对象
5、右外连接
(1)hql 语句
from Customer c right outer join c.linkManSet
(2)右外连接返回的 List 中,每部分都是一个数组
「注意:没有迫切右外连接」
【made by siwuxie095】
HQL多表查询的更多相关文章
- Hibernate hql 多表查询
String hql="select c from Col c ,UserRole role where c.id=role.columnId and c.id=? and role.use ...
- Hibernate HQL多表查询
1.内连接和迫切内连接 (1)内连接 HQL语句:from 实体类名 实体类别名 inner join 实体类别名.表示另一个表数据的集合名称 (2)迫切内连接 HQL语句:from 实体类名 实体类 ...
- Hibernate的HQL多表查询
HQL的内连接查询 对于HQL内链接查询,查询的是两张表的数据,这两张表的数据首先是保存在数组之中,然后在将每一个数组保存在List集合之中进行返回 代码片段: @Test // 内连接 public ...
- hql 多表查询
sql 单表/多表查询去除重复记录单表distinct多表group by select h from Hytxbz as h,Tgbzk as t where h.hytxbzid=t.hytxbz ...
- Hibernate_day04--HQL多表查询_Hibernate检索策略
HQL多表查询 Mysql里面多表查询 1 内连接 查的是两个表关联的数据 2 左外连接 查的是左边表所有数据,右边表关联数据 3 右外连接 HQL实现多表查询 Hql多表查询 (1)内连接 (2)左 ...
- HQL之多表查询(一对多和多对多)
一.一对多 以班级Classes和学生Student为例: 回忆sql语句: //内链接,两种方式效果一样,查询的是两边都有的数据 SELECT c.*,s.* FROM classes c,st ...
- jpa 联表查询 返回自定义对象 hql语法 原生sql 语法 1.11.9版本
-----业务场景中经常涉及到联查,jpa的hql语法提供了内连接的查询方式(不支持复杂hql,比如left join ,right join). 上代码了 1.我们要联查房屋和房屋用户中间表,通过 ...
- Hibernate中的HQL的基本常用小例子,单表查询与多表查询
<span style="font-size:24px;color:#3366ff;">本文章实现HQL的以下功能:</span> /** * hql语法: ...
- sql多表查询时怎么获取查到的字段
首先,多表查询不能用hql(貌似hql就是不支持多表查询,如果可以,希望看到的朋友给个例子) List list = systemService.findListbySql("SELECT ...
随机推荐
- 【转】python 字符编码与解码——unicode、str和中文:UnicodeDecodeError: 'ascii' codec can't decode
原文网址:http://blog.csdn.net/trochiluses/article/details/16825269 摘要:在进行python脚本的编写时,如果我们用python来处理网页数据 ...
- MyEclipse中将普通Java项目convert(转化)为Maven项目
在MyEclipse10中将Maven项目转成普通Java项目后,想将Java项目转成Maven项目,结果一下子傻眼了.根本就没有攻略中提到的config标签.仔细一看,喵咪的,人家用的是Eclips ...
- C#操作PowerDesigner代码
首先,程序的界面如下:
- SQL Server数据库常用的T-SQL命令
1. 查看数据库的版本 select @@version 2.查看数据库所在机器操作系统参数 exec master..xp_msver 3. 查看数据库启动的参数 sp_configure 4.查看 ...
- h264 aac 封装 flv
Part 1flvtag组成 FLV 文件结构由 FLVheader和FLVBody组成.(注意flv文件是大端格式的)FLV头组成(以c为例子,一字节对齐):FLVBody是由若干个Tag组成的: ...
- 杂项:SpagoBI
ylbtech-杂项:SpagoBI SpagoBI是一个商业智能平台,为商业智能项目提供了一个完整开源的解决方案.它涵盖了一个BI系统所有方面的功能包括:数据挖掘.查询.分析.报告.Dashboar ...
- python3第一次作业
需要一个文件users,里面有用户名密码以及是否锁定的标识符 lzd--123--1wdl--123--0lw--123--0aaa--123--0bbb--123--0ccc--123--1ddd- ...
- node的close
在http.ServerResponse对象的end方法被调用之前,如果连接被中断,将触发http.ServerResponse对象的close事件. var http=require("h ...
- django No migrations to apply 问题解决
最近在用django写项目,有的时候字段不够用,需要models增加字段,但是想回滚或者修改或者修改了属性等,例如忘了添加meta table于是操作了migrations 导致makemigrati ...
- 关于setTimeout的一个逻辑题
function hh() { for (var i = 1; i <=5; i++) { setTimeout(function(){ console.log(i); },100) } con ...