HQL多表查询
来源:互联网 发布:java中方法的返回值 编辑:程序博客网 时间:2024/05/22 10:24
**技术分析之HQL多表查询**
1. 多表的查询进来使用HQL语句进行查询,HQL语句和SQL语句的查询语法比较类似。
* 内连接查询
* 显示内连接
* select * from customers c inner join orders o on c.cid = o.cno;
* 隐式内连接
* select * from customers c,orders o where c.cid = o.cno;
* 外连接查询
* 左外连接
* select * from customers c left join orders o on c.cid = o.cno;
* 右外连接
* select * from customers c right join orders o on c.cid = o.cno;
2. HQL的多表查询
* 迫切和非迫切:
* 非迫切返回结果是Object[]
* 迫切连接返回的结果是对象,把客户的信息封装到客户的对象中,把订单的信息封装到客户的Set集合中。
3. 内连接查询
* 内连接使用 inner join ,默认返回的是Object数组
Session session = HibernateUtils.getCurrentSession();
Transaction tr = session.beginTransaction();
List<Object[]> list = session.createQuery("from Customer c inner join c.linkmans").list();
for (Object[] objects : list) {
System.out.println(Arrays.toString(objects));
}
tr.commit();
* 迫切内连接:inner join fetch ,返回的是实体对象
Session session = HibernateUtils.getCurrentSession();
Transaction tr = session.beginTransaction();
List<Customer> list = session.createQuery("from Customer c inner join fetch c.linkmans").list();
Set<Customer> set = new HashSet<Customer>(list);
for (Customer customer : set) {
System.out.println(customer);
}
tr.commit();
4. 左外连接查询
* 左外连接: 封装成List<Object[]>
* 迫切左外连接
Session session = HibernateUtils.getCurrentSession();
Transaction tr = session.beginTransaction();
List<Customer> list = session.createQuery("from Customer c left join fetch c.linkmans").list();
Set<Customer> set = new HashSet<Customer>(list);
for (Customer customer : set) {
System.out.println(customer);
}
tr.commit();
1. 多表的查询进来使用HQL语句进行查询,HQL语句和SQL语句的查询语法比较类似。
* 内连接查询
* 显示内连接
* select * from customers c inner join orders o on c.cid = o.cno;
* 隐式内连接
* select * from customers c,orders o where c.cid = o.cno;
* 外连接查询
* 左外连接
* select * from customers c left join orders o on c.cid = o.cno;
* 右外连接
* select * from customers c right join orders o on c.cid = o.cno;
2. HQL的多表查询
* 迫切和非迫切:
* 非迫切返回结果是Object[]
* 迫切连接返回的结果是对象,把客户的信息封装到客户的对象中,把订单的信息封装到客户的Set集合中。
3. 内连接查询
* 内连接使用 inner join ,默认返回的是Object数组
Session session = HibernateUtils.getCurrentSession();
Transaction tr = session.beginTransaction();
List<Object[]> list = session.createQuery("from Customer c inner join c.linkmans").list();
for (Object[] objects : list) {
System.out.println(Arrays.toString(objects));
}
tr.commit();
* 迫切内连接:inner join fetch ,返回的是实体对象
Session session = HibernateUtils.getCurrentSession();
Transaction tr = session.beginTransaction();
List<Customer> list = session.createQuery("from Customer c inner join fetch c.linkmans").list();
Set<Customer> set = new HashSet<Customer>(list);
for (Customer customer : set) {
System.out.println(customer);
}
tr.commit();
4. 左外连接查询
* 左外连接: 封装成List<Object[]>
* 迫切左外连接
Session session = HibernateUtils.getCurrentSession();
Transaction tr = session.beginTransaction();
List<Customer> list = session.createQuery("from Customer c left join fetch c.linkmans").list();
Set<Customer> set = new HashSet<Customer>(list);
for (Customer customer : set) {
System.out.println(customer);
}
tr.commit();
阅读全文
0 0
- hql 多表查询
- hql多表查询
- HQL多表查询
- HQL多表查询
- HQL多表查询
- HQL多表查询
- HQL多表查询
- HQL的多表查询
- hql 多表连接查询
- HQL的多表查询
- hibernate多表查询HQL
- hibernate多表查询HQL
- HQL查询多表数据
- HQL语句多表查询
- hql多表联合查询
- hibernate多表查询HQL
- hql多表关联查询
- hibernate多表查询HQL
- Docker swarm中跳出加入manage or worker的指令
- SoapUI中新建REST
- 【树状数组】poj 3067 Japan(树状数组求逆序数)
- Set容器使用指针的一些问题
- laravel基础
- HQL多表查询
- 在Eclipse 中设置JVM 内存
- leetcode[Third Maximum Number]
- 9265:取数游戏
- SpringAOP动态拦截方法并重写
- Kotlin系统入门与进阶(一)
- Java中使用TCP协议的简单连接
- 利用ES6中的模板字符串轻松实现多行和字符串值的插入
- maven exclude 排除文件夹