Chinaunix首页 | 论坛 | 博客
  • 博客访问: 29950967
  • 博文数量: 708
  • 博客积分: 12163
  • 博客等级: 上将
  • 技术积分: 8240
  • 用 户 组: 普通用户
  • 注册时间: 2007-12-04 20:59
文章分类

全部博文(708)

分类: Java

2008-06-12 11:18:11

http://wiley.javaeye.com/blog/31631?page=2

 

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

Java代码 复制代码
  1. ......   
  2.   
  3.  "noteses" inverse="true">   
  4.         
  5.          "userid" not-null="true" />   
  6.         
  7.      class="com.note.model.Notes" />   
  8.     
  9.   
  10. .....  



Notes.hbm.xml

Java代码 复制代码
  1. ......   
  2.   
  3.   "users" class="com.note.model.Users" fetch="select">   
  4.       "userid" not-null="true" />   
  5.      
  6.   
  7. ......  



注意:如果多表查询,在写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
  5.     Object[] obj=(Object[])list.get(i);   
  6.     for(int j=0;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. }  
阅读(2580) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~