快速业务通道

Hibernate属性查询简介 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-14

Hibernate属性查询简介

时间:2011-11-09

本文向大家介绍Hibernate属性查询,可能好多人还不了解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 select upper(user.name) from TUser as user select distinct user.name from TUser as user

以上介绍Hibernate属性查询。

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号