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

《深入浅出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
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值