hibernate多表查询

阅读更多
百事通信息网


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

       ......

        
            
                
            
            
        

      ......


Notes.hbm.xml

      ......

        
            
        

      ......


注意:如果多表查询,在写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 
 

在jsp页面显示结果的时候我觉得用EL表达式会简单的多,如:

		
			
				
主题:${objs[0].title} 作者:${objs[1].username} 发贴时间:${objs[0].addtime}

你可能感兴趣的:(Hibernate,DWR,Spring,算法,AOP)