锁定老帖子 主题:hibernate多表查询
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2006-10-30
最后修改:2009-11-10
百事通信息网
我的demo小程序随着我学习的过程、体积也越来越庞大起来了、开始只是用来测试hibernate、渐渐的Spring,struts,dwr(我在用来做验证的过程因为异步,效果反而不好,所以后来拿掉了)的身影也出现了,到如今他已经有注册、登陆、发贴、查看主题、查看跟贴,回贴的能耐了,呵呵,为他而高兴。在前面学习的过程中先避开一些难点,比如多表查询、AOP切面编程等等,不过为了满足需求,今天开始将多表应用上去了,确实遇到了不少麻烦,花了不少的时间,当然在遇到问题,解决问题的过程中让我回顾了很多要点、盲点,也值了。 现在将关键点记录下来,以免日后再有相同问题出现,以便查阅。 二张表分别为用户表(users)和贴子表(notes),其中users中的userid是notes表的外键,users跟notes是一对多,多对一关系,由myEclpise自动生成映射文件 Users.hbm.xml ...... <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 ...... <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集,可以用以下代码测试 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表达式会简单的多,如: <logic:present name="subjects"> <table width="100%" border="1" rules="rows" frame="below" cellpadding="5" cellspacing="0" bordercolorlight="#6C7BA6" bordercolordark="#ffffff" bgcolor="#DEEFFF" class="DoubleColorTable"> <logic:present name="subjects" property="result"> <logic:iterate id="objs" name="subjects" indexId="number" property="result"> <tr> <td> <html:link page="/listFollow.do?method=listFollow&subjectId=${objs[0].noteid}" styleId="link001"> 主题:${objs[0].title} </html:link> </td> <td> 作者:${objs[1].username} </td> <td> 发贴时间:${objs[0].addtime} </td> </tr> </logic:iterate> </logic:present> </table> <bean:write name="subjects" property="pageToolBar" filter="false" /> </logic:present> 声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2006-11-01
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()); } 当obj[j]为null时的情况,怎么样处理呢 |
|
返回顶楼 | |
发表时间:2006-11-01
obj[j]应该不会出现null,只有list才有可能出现null所以在循环外加if判断就可以了
|
|
返回顶楼 | |
发表时间:2006-11-01
我把你的查选考虑成外连接了,如果是外连接,会有出现null的情况
|
|
返回顶楼 | |
发表时间:2006-11-02
这样做很好啊,不如用排序组合算法算了。拿出数据集合还需新组装成页面需求集合,几乎说是严重浪费人力物力表现。真不知道你是如何想得。 |
|
返回顶楼 | |
发表时间:2006-11-02
注意:如果多表查询,在写HQL语句时取notes的userid字段不能写notes.userid(这个问题下午我查了好久,才找到原因的)
HQL语句:From Notes notes,Users users WHERE notes.users=users.userid AND notes.issubject=1 问下 为何不能写成notes.userid 而要notes.users? |
|
返回顶楼 | |
发表时间:2006-11-02
引用 注意:如果多表查询,在写HQL语句时取notes的userid字段不能写notes.userid(这个问题下午我查了好久,才找到原因的)
HQL语句:From Notes notes,Users users WHERE notes.users=users.userid AND notes.issubject=1 问下 为何不能写成notes.userid 而要notes.users? Users(POJO)中没有userid成员 |
|
返回顶楼 | |
发表时间:2006-11-02
to:santafeng
引用 这样做很好啊,不如用排序组合算法算了。拿出数据集合还需新组装成页面需求集合,几乎说是严重浪费人力物力表现。真不知道你是如何想得。
我也是初学hibernate,并不是很深入,你能详述你在多表查询时的做法吗?谢谢 |
|
返回顶楼 | |
发表时间:2006-11-02
wiley 写道 to:santafeng
引用 这样做很好啊,不如用排序组合算法算了。拿出数据集合还需新组装成页面需求集合,几乎说是严重浪费人力物力表现。真不知道你是如何想得。
我也是初学hibernate,并不是很深入,你能详述你在多表查询时的做法吗?谢谢 这种设计使用hibernate无疑是鸡肋表现,无法解决。 |
|
返回顶楼 | |
发表时间:2006-11-02
santafeng 写道 wiley 写道 to:santafeng
引用 这样做很好啊,不如用排序组合算法算了。拿出数据集合还需新组装成页面需求集合,几乎说是严重浪费人力物力表现。真不知道你是如何想得。
我也是初学hibernate,并不是很深入,你能详述你在多表查询时的做法吗?谢谢 这种设计使用hibernate无疑是鸡肋表现,无法解决。 那什么样的设计才使用hibernate呢? |
|
返回顶楼 | |