《深入浅出Hibernate》实在是本好书,使用Hibernate的人都应该读一读,夏昕写的文章的确读起来不累,有些书是读起来很累的。。。
今天说一下属性查询:使用HQL的时候并不是把 hbm.xml 里面的所有属性取出来,只取出有用的属性便可以了,举个例子:
| List list = session.createQuery("select user.name,user.age from TUSER user").list(); Iterator it = list.iterator(); while(it.hasNext()) ...{ Object[] results = (Object[])it.next(); System.out.println(results[0]); System.out.println(results[1]); } |
如果觉得返回数组的方式不够符合面向对象的风格,也可以使用构造对象实例的方法对数组进行封装:
| List list = this.session.createQuery(" select new TUser(user.name,user.age) from TUser as user").list(); Iterator if = list.iterator(); while(it.hasNext()) ...{ TUser user = (TUser)it.next(); System.out.println(user.getName()); } |
着爱与那个就比较形象化一些,但是有一点要注意的是这个查询结果的TUser对象仅仅是一普通的 java 对象,进用于对查询结果的封装,除了在构造是赋予的属性值外,其他属性均为未赋值状态,这就意味着,我们无法通过 Session 对此对象进行更新,如果企图对 user 对象更新将导致向数据库插入一条新的记录,而不是更新原有记录:
| while(it.hasNext()) ...{ TUser user = (TUser)it.next(); user.setName("test"); session.saveOrUpdate(user);//这里将导致一次 insert 操作,而非 update } |
也可以使用像 SQL 那样的统计函数,比如:
|
selet count(*),min(user.age) from TUser as user |
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
相关专题
- SQL Server 索引和查询专题 (3389篇文章)
- Hibernate原理与配置 (368篇文章)
- Hibernate相关文章 (368篇文章)
- Java远程通讯可选技术及原理 (145次浏览)
- Java基础知识:初学者必须理解的六大问题 (76次浏览)
- 九个非常值得一看的MySpace程序 (72次浏览)
- Java初学者必须理解的六个大问题 (70次浏览)
- 微软企业级平台呼之欲出 英雄由“此”诞生 (66次浏览)
- Java基础知识:谈谈简单Hibernate入门 (58次浏览)
- struts验证框架开发详解 (48次浏览)
- Java入门-浅析Java学习从入门到精通 (47次浏览)
- 关于提高自己水平的十大技术 (47次浏览)
- Flex测试工具RIATest Beta版发布 (45次浏览)



