打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
hibernate多表查询
二张表分别为用户表(users)和贴子表(notes),其中users中的userid是notes表的外键,users跟notes是一对多,多对一关系,由myEclpise自动生成映射文件
Users.hbm.xml

Java代码
  1. ......  
  2.   
  3.  <set name="noteses" inverse="true">  
  4.      <key>  
  5.          <column name="userid" not-null="true" />  
  6.      </key>  
  7.      <one-to-many class="com.note.model.Notes" />  
  8.  </set>  
  9.   
  10. .....  
       ......<set name="noteses" inverse="true"><key><column name="userid" not-null="true" /></key><one-to-many class="com.note.model.Notes" /></set>......


Notes.hbm.xml

Java代码
  1. ......  
  2.   
  3.   <many-to-one name="users" class="com.note.model.Users" fetch="select">  
  4.       <column name="userid" not-null="true" />  
  5.   </many-to-one>  
  6.   
  7. ......  
      ......<many-to-one name="users" class="com.note.model.Users" fetch="select"><column name="userid" not-null="true" /></many-to-one>......


注意:如果多表查询,在写HQL语句时取notes的userid字段不能写notes.userid(这个问题下午我查了好久,才找到原因的)

HQL语句:From Notes notes,Users users WHERE notes.users=users.userid AND notes.issubject=1

又一注意点:该查询结果为存放对象数组的list集,可以用以下代码测试

Java代码
  1.                    page=ins.listSubjects(page);//page是我的分页类,并存放了查询后的返回结果  
  2. List list=page.getResult();  
  3. System.out.println(page.getPageToolBar());  
  4. for(int i=0;i<list.size();i++){  
  5.     Object[] obj=(Object[])list.get(i);  
  6.     for(int j=0;j<obj.length;j++){  
  7.         if(obj[j] instanceof Notes){  
  8.             Notes note=(Notes)obj[j];  
  9.             System.out.print(note.getTitle());  
  10.               
  11.         }else if(obj[j] instanceof Users){  
  12.             Users user=(Users)obj[j];  
  13.             System.out.print(user.getUsername());  
  14.         }  
  15.     }  
  16.     System.out.println();  
  17. }  
                     page=ins.listSubjects(page);//page是我的分页类,并存放了查询后的返回结果List list=page.getResult();System.out.println(page.getPageToolBar());for(int i=0;i<list.size();i++){Object[] obj=(Object[])list.get(i);for(int j=0;j<obj.length;j++){if(obj[j] instanceof Notes){Notes note=(Notes)obj[j];System.out.print(note.getTitle());}else if(obj[j] instanceof Users){Users user=(Users)obj[j];System.out.print(user.getUsername());}}System.out.println();}


在jsp页面显示结果的时候我觉得用EL表达式会简单的多,如:
Java代码
  1. <logic:present name="subjects">  
  2.         <table width="100%" border="1" rules="rows" frame="below" cellpadding="5" cellspacing="0" bordercolorlight="#6C7BA6" bordercolordark="#ffffff" bgcolor="#DEEFFF" class="DoubleColorTable">  
  3.             <logic:present name="subjects" property="result">  
  4.             <logic:iterate id="objs" name="subjects" indexId="number" property="result">  
  5.                 <tr>  
  6.                     <td>  
  7.                     <html:link page="/listFollow.do?method=listFollow&subjectId=${objs[0].noteid}"  styleId="link001">  
  8.                         主题:${objs[0].title}  
  9.                     </html:link>  
  10.                     </td>  
  11.                     <td>  
  12.                     作者:${objs[1].username}  
  13.                     </td>  
  14.                     <td>  
  15.                     发贴时间:${objs[0].addtime}  
  16.                     </td>  
  17.                 </tr>  
  18.             </logic:iterate>  
  19.             </logic:present>  
  20.         </table>  
  21.         <bean:write name="subjects" property="pageToolBar" filter="false" />  
  22.     </logic:present> 
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
java8 新特性 Stream流 分组 排序 过滤 多条件去重
几种Java序列化方式的实现
Chapter 1. A Introduction. Problem Background
Installing the Cygwin SSH daemon
mybatis的association和collection的用法
java 简单servlet实例
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服