您的位置:首页 > 移动开发 > Objective-C

《深入浅出Hibernate》读书笔记1——属性查询

2008-04-24 12:07 176 查看
《深入浅出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
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息