频道直达 - 专题 - 新闻 - 技巧 - 组网 - 开发 - 安全 - web编程 - 图像 - 操作系统 - 数据库 - 教育 - 旅游 - 健康 - 时尚 - 驱动 - 软件 - 游戏 - 多媒体 - ERP - 讨论组

深入浅出Hibernate的属性查询

来源: 作者:佚名 出处:巧巧读书 2008-04-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

更多文章 更多内容请看SQL Server 索引和查询专题Hibernate原理与配置Hibernate相关文章专题,或进入讨论组讨论。
收藏此文】【 】【打印】【关闭
相关图文阅读
频道图文推荐
健 康 咨 询
时 尚 咨 询
巧巧读书宗旨
相关专题
讨论组问题推荐
站内各频道最新更新文档
站内最新制作专题
热门关键字导读
Photoshop教 程照片处理 照片制作 PS快捷键 抠图
计 算 机 故 障XP系统修复
艺 术 与 设 计设计 流媒体 设计欣赏 边框
计 算 机 安 全ARP
站内频道文章精选
巧巧电脑频道编辑信箱  告诉我们您想看的专题或文章