hibernate多表查询

我的demo小程序随着我学习的过程、体积也越来越庞大起来了、开始只是用来测试hibernate、渐渐的Spring,struts,dwr(我在用来做验证的过程因为异步,效果反而不好,所以后来拿掉了)的身影也出现了,到如今他已经有注册、登陆、发贴、查看主题、查看跟贴,回贴的能耐了,呵呵,为他而高兴。在前面学习的过程中先避开一些难点,比如多表查询、AOP切面编程等等,不过为了满足需求,今天开始将多表应用上去了,确实遇到了不少麻烦,花了不少的时间,当然在遇到问题,解决问题的过程中让我回顾了很多要点、盲点,也值了。
    现在将关键点记录下来,以免日后再有相同问题出现,以便查阅。
二张表分别为用户表(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>  

转自:

http://www.matrix.org.cn/thread.shtml?topicId=0c24a650-6812-11db-bdce-bdc029e475a1&forumId=23&fid=23

http://wiley.javaeye.com/blog/31631

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值