站长百科 | 数字化技能提升教程 数字化时代生存宝典
首页
数字化百科
电子书
▼
建站程序
开发
服务器
办公软件
开发教程
▼
服务器教程
软件使用教程
运营教程
热门电子书
▼
CSS教程
WordPress教程
导航
程序频道
推广频道
网赚频道
人物频道
网站程序
网页制作
云计算
服务器
CMS
论坛
网店
虚拟主机
cPanel
网址导航
WIKI使用导航
WIKI首页
热点词条
最新资讯
网站程序
站长人物
页面分类
使用帮助
编辑测试
创建条目
网站地图
站长百科导航
站长百科
主机侦探
IDCtalk云说
跨境电商导航
WordPress啦
站长专题
网站推广
网站程序
网站赚钱
虚拟主机
cPanel
网址导航专题
云计算
微博营销
虚拟主机管理系统
开放平台
WIKI程序与应用
美国十大主机
编辑“
HQL
”(章节)
人物百科
|
营销百科
|
网赚百科
|
站长工具
|
网站程序
|
域名主机
|
互联网公司
|
分类索引
跳转至:
导航
、
搜索
警告:
您没有登录。如果您做出任意编辑,您的IP地址将会公开可见。如果您
登录
或
创建
一个账户,您的编辑将归属于您的用户名,且将享受其他好处。
反垃圾检查。
不要
加入这个!
===属性查询=== *很多时候在检索数据时,并不需要获得实体对象所对应的全部数据,而只需要检索实体对象的部分属性所对应的数据。这时候就可以利用HQL属性查询技术,如下面[[程序]]示例: <pre> List list=session.createQuery(“selectuser.namefromUseruser”).list(); for(int i=0;i<list.size();i ){ System.out.println(list.get(i)); } </pre> *只检索了User实体的name属性对应的数据,此时返回的包含结果集的list中每个条目都是String类型的name属性对应的数据。我们也可以一次检索多个属性,如下面程序: <pre> List list=session.createQuery(“select user.name,user.age from User user ”).list(); for(int i=0;i Object[] obj=(Object[])list.get(i); System.out.println(obj[0]); System.out.println(obj[1]); } </pre> *此时返回的结果集list中,所包含的每个条目都是一个Object[]类型,其中包含对应的属性数据值。可能会觉得上面返回Object[]不够符合面向对象风格,可以利用HQL提供的动态构造实例的功能对这些平面数据进行封装,如下面的程序代码: <pre> Listlist=session.createQuery(“selectnewUser(user.name,user.age)fromUseruser”).list(); for(inti=0;i Useruser=(User)list.get(i); System.out.println(user.getName()); System.out.println(user.getAge()); } </pre> 通过动态构造实例对象,对返回结果进行了封装,使程序更加符合面向对象风格,但是这里有一个问题必须注意,那就是这时所返回的User对象,仅仅只是一个普通的Java对象而以,除了查询结果值之外,其它的属性值都为null(包括主键值id),也就是说不能通过[[Session]][对象]]对此对象执行持久化的更新操作。如下面的代码: <pre> Listlist=session.createQuery(“selectnewUser(user.name,user.age)fromUseruser”).list(); for(inti=0;i Useruser=(User)list.get(i); user.setName(“gam”); session.saveOrUpdate(user); //这里将会实际执行一个save操作, //而不会执行update操作,因为这个User对象的id属性为null, //Hibernate会把它作为一个自由对象 //(请参考持久化对象状态部分的论述), //因此会对它执行save操作。 } </pre>
摘要:
请注意,您对站长百科的所有贡献都可能被其他贡献者编辑,修改或删除。如果您不希望您的文字被任意修改和再散布,请不要提交。
您同时也要向我们保证您所提交的内容是您自己所作,或得自一个不受版权保护或相似自由的来源(参阅
Wordpress-mediawiki:版权
的细节)。
未经许可,请勿提交受版权保护的作品!
取消
编辑帮助
(在新窗口中打开)