首页 | 互联网 | IT动态 | Cisco | Windows | Linux | Java | .Net | Oracle | 华为 | 存储世界 | 服务器 | 网络设备 | IDC | 安全 | 求职招聘
IT培训 | 数字网校 | 技术专题 | 电子书下载 | 教学视频 | 网页设计 | 平面设计 | 解决方案 | 直播室 | 虚拟考场 | 搜索 | 博客 | 沙龙 | 论坛
中国IT实验室Linux频道
中国IT教育
 
首页 资讯动态 认证考试 新手入门 核心技术 高级技术 J2EE J2ME Java&XML 开源技术 其他技术 RSS订阅 论坛 专题
您现在的位置: 中国IT实验室 >> Java >> 开源技术 >> Hibernate >> 文章正文

深入浅出Hibernate的属性查询

文章来源中国IT实验室收集整理 作者佚名 更新时间2008-4-25 保存本文保存本文 推荐给好友推荐给好友 收藏本页收藏本页

    《深入浅出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

 

【责编:Ken】

中国IT教育

相关产品和培训
文章评论
 友情推荐链接
 认证培训
 专题推荐

 ·XML全攻略技术专题
 ·JAVA开源技术介绍专题
 ·Java嵌入式开发之J2ME技术专题
 ·超前体验 Oracle 11g的5个新特性
 ·揭密使用VB.NET的五个实用技巧
 ·Oracle和SQL Server常用函数对比专题
 ·展现C#世界 C#程序设计专题
 ·Java入门 Tomcat的配置技巧精华专题
 ·Oracle RMAN物理备份技术详解
 ·JAVA开发利器——JBuilder知多少
 今日更新
 社区讨论
 博客论点
 频道精选
 Java 频道导航