Hibernate连接查询join
2016-08-25 19:49
357 查看
主表Owner 从表Tea
Owner及Tea的pojo
import java.util.HashSet;
import java.util.Set;
public class Owner {
private int id;
private String name;
private String Address;
private Set<Tea> set=new HashSet<Tea>();
....}
1.查询对象:直接查询返回一个符合条件的Object[][]的List
public void test10(){
String hql=" from Owner o join o.set where owner_id = :newName";
Query query=session.createQuery(hql);
List<Object[]> list=query.setInteger("newName", 103).list();
tx.commit();
Iterator it=list.iterator();
while(it.hasNext()){
Object[] o=(Object[]) it.next();
System.out.print(o[0]);
System.out.println(o[1]);
}
}
结果:
Owner [id=103, name=李华_1, Address=合肥_1]Tea [id=205, name=2, sales=2]
Owner [id=103, name=李华_1, Address=合肥_1]Tea [id=206, name=3, sales=3]
2.查询对象:在查询对象前加上distinct 这时只返回一个符合条件的主表对象的List
3.查询属性:查询单个属性时返回一个Object查询多个属性时返回一个Object[][][][]....
distinct可加可不加
@Test
public void test1(){
String hql="select o.name from Owner o inner join o.set teas where teas.name= :a";
Query query=session.createQuery(hql);
query.setString("a","2");
// query.setInteger("b", 4);
List<String> olist=query.list();
tx.commit();
for(String s:olist){
System.out.println(s);
}
}
Owner及Tea的pojo
import java.util.HashSet;
import java.util.Set;
public class Owner {
private int id;
private String name;
private String Address;
private Set<Tea> set=new HashSet<Tea>();
....}
public class Tea { private int id; private int name; private int sales; private Owner owener;
......}
1.查询对象:直接查询返回一个符合条件的Object[][]的List
<pre class="java" name="code">@Test
public void test10(){
String hql=" from Owner o join o.set where owner_id = :newName";
Query query=session.createQuery(hql);
List<Object[]> list=query.setInteger("newName", 103).list();
tx.commit();
Iterator it=list.iterator();
while(it.hasNext()){
Object[] o=(Object[]) it.next();
System.out.print(o[0]);
System.out.println(o[1]);
}
}
结果:
Owner [id=103, name=李华_1, Address=合肥_1]Tea [id=205, name=2, sales=2]
Owner [id=103, name=李华_1, Address=合肥_1]Tea [id=206, name=3, sales=3]
2.查询对象:在查询对象前加上distinct 这时只返回一个符合条件的主表对象的List
@Test public void test10(){ String hql=" select distinct o from Owner o join o.set where owner_id = :newName"; Query query=session.createQuery(hql); List<Owner> list=query.setInteger("newName", 103).list(); tx.commit(); Iterator it=list.iterator(); while(it.hasNext()){ System.out.println(it.next().toString()); } }查询结果:
</pre></p><pre class="java" name="code">Owner [id=103, name=李华_1, Address=合肥_1]
3.查询属性:查询单个属性时返回一个Object查询多个属性时返回一个Object[][][][]....
distinct可加可不加
@Test
public void test1(){
String hql="select o.name from Owner o inner join o.set teas where teas.name= :a";
Query query=session.createQuery(hql);
query.setString("a","2");
// query.setInteger("b", 4);
List<String> olist=query.list();
tx.commit();
for(String s:olist){
System.out.println(s);
}
}
相关文章推荐
- hibernate 查询与连接 (接上篇)
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- hibernate使用sum聚集函数,时间段为查询条件连接SQL2005
- LinQ 标准的查询操作符 连接 join in on equals
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- 多表查询,join,内联接,substr,字符串连接,to_char,Sysdate,to_date,嵌套查询
- 使用join对数据表进行连接查询
- 在Hibernate中使用HQL通过Join进行关联查询
- 表连接查询INNER JOIN/OUTER JOIN/CROSS JOIN
- JOIN连接查询
- 使用连接(JOIN)来代替子查询(Sub-Queries) mysql优化系列记录
- 通过hibernate session.connection()获得数据库连接时,导致的查询缓慢甚至假死机问题
- SQL基础回顾--连接查询JOIN
- hibernate 查询 内连接还是外连接 ?
- Hibernate学习35 -- Hibernate查询语言(HQL)9 -- 连接查询
- join 连接查询
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- 在使用Hibernate时,因为一个查询需要更多的表连接而要使用SQL来解决性能问题。然而返回的结果集中包含了没有映射的Entity类中的表字段,在这个SQL中还有使用如何将层次关系的父子结点显示为横行
- sql多表连接查询inner join, left join , right join ,full join ,cross join
- 关于Hibernate、NHibernate的 HQL 连接字段,字段拼接查询问题