欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

JSP 开发之hibernate的hql查询多对多查询

程序员文章站 2024-02-27 19:39:03
jsp 开发之hibernate的hql查询多对多查询 在hibernate的hql查询中,假如说分组信息与试题是多对多关系,那么我们要在hql查询中对含有多个分组信息的...

jsp 开发之hibernate的hql查询多对多查询

在hibernate的hql查询中,假如说分组信息与试题是多对多关系,那么我们要在hql查询中对含有多个分组信息的试题都要查询出来。并同时查询出相应试题的分组信息。那么此时hql要这样写:

 string[] groupids = ojbects[1].tostring().split(","); 
 string hql = "select distinct a.id from tmeduexamcontent a"; 
if(!"".equals(groupids[0])){ 
  hql += " join a.groups as b "; 
} 
 hql += "and ( "; 
    for(int i=0;i<groupids.length;i++){ 
      hql += "b.id="+groupids[i] + " "; 
      if(i != groupids.length-1){ 
        hql += "or "; 
      } 
    } 
    hql += ") "; 

附上多对多配置:

引用

  <set name="groups" table="tm_education_content_group" outer-join="false"> 
<key column="content_id" /> 
<many-to-many class="com.gd.po.classiccasesgroup" column="group_id" /> 
</set> 
<set name="modelcontents" table="tm_modelcontent_group" outer-join="false"> 
<key column="group_id" /> 
<many-to-many class="com.gd.po.tmeduexammodelcontent" column="modelcontent_id" /> 
</set> 

如有疑问请留言或者到本站社区交流讨论,感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!