本文向大家介绍Hibernate属性查询可能好多人还不了解Hibernate属性查询没有关系看完本文 你肯定有不少收获希望本文能教会你更多东西
今天说一下Hibernate属性查询使用HQL的时候并不是把 hbmxml 里面的所有属性取出来只取出有 用的属性便可以了举个例子
Listlist=sessioncreateQuery
(selectusernameuseragefromTUSERuser)list();
Iteratorit=erator();
while(ithasNext())
{
Object[]results=(Object[])itnext();
Systemoutprintln(results[]);
Systemoutprintln(results[]);
}
如果觉得返回数组的方式不够符合面向对象的风格也可以使用构造对象实例的方法对数组进行封装
Listlist=thissessioncreateQuery
(selectnewTUser(usernameuserage)fromTUserasuser)list();
Iteratorif=erator();
while(ithasNext())
{
TUseruser=(TUser)itnext();
Systemoutprintln(usergetName());
}
着爱与那个就比较形象化一些但是有一点要注意的是这个查询结果的TUser对象仅仅是一普通的 java 对象进用于对查询结果的封装除了在构造是赋予的属性值外其他属性均为未赋值状态这就 意味着我们无法通过 Session 对此对象进行更新如果企图对 user 对象更新将导致向数据库插入一 条新的记录而不是更新原有记录
while(ithasNext())
{
TUseruser=(TUser)itnext();
usersetName(test);
sessionsaveOrUpdate(user);
//这里将导致一次insert操作而非update
}
也可以使用像 SQL 那样的统计函数比如
seletcount(*)min(userage)fromTUserasuser
selectupper(username)fromTUserasuser
selectdistinctusernamefromTUserasuser
以上介绍Hibernate属性查询