《深入浅出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
今天说一下属性查询:使用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
相关文章推荐
- 【Android學習專題】視覺介面篇:Android布局及属性归总(查询用)《转自cnblog》
- Dynamics CRM2016 Web Api之查询查找字段的相关属性
- hql语句实现查询对象部分属性
- hibernate 多对多注解配置及实体属性条件查询
- 数据表字段属性查询
- ASP.NET查询页面设置form的action属性只弹出一个页面,并且每次将页面设置到最前
- AutoLISP查询直线的相关属性
- arcgis engine空间查询与属性查询的主要代码
- 一种查询表详细属性的方法
- mysql -- 查询表所有字段的属性和注释
- 使用mybatis,在添加数据的时候返回主键,当查询count和属性字段怎么接收返回数据
- ArcGIS Engine开发之属性查询
- 关于Hibernate底层的查询处理(忽略大小写,模糊匹配,自动加载属性)
- hibernate的HQL查询部分属性
- jQuery能否按用户自定义的属性查询对象
- CSS border-style 属性查询
- crm查询实体的字段属性
- ArcGis属性条件查询
- 查询属性 - 方法属性
- Spring Data JPA根据属性名查询方法