ImageVerifierCode 换一换
格式:DOCX , 页数:5 ,大小:16.44KB ,
资源ID:6695912      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6695912.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(Hibernate的数据过滤查询.docx)为本站会员(b****5)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

Hibernate的数据过滤查询.docx

1、Hibernate的数据过滤查询数据过滤并不是一种常规的数据查询方法,而是一种整体的筛选方法。数据过滤也可对数据进行筛选,因此,将其放在Hibernate的数据查询框架中介绍。如果一旦启用了数据过滤器,则不管数据查询,还是数据加载,该过滤器将自动作用于所有数据,只有满足过滤条件的记录才会被选出来。过滤器与定义在类和集合映射文件上的“where”属性非常相似。它们的区别是过滤器可以带参数,应用程序可以在运行时决定是否启用指定的过滤器,以及使用什么样的参数值。而映射文件上的“where”属性将一直生效,且无法动态传入参数。过滤器的用法很像数据库视图,区别是视图在数据库中已经定义完成,而过滤器则还需

2、在应用程序中确定参数值。过滤器的使用分成三步:(1)定义过滤器。使用filter-def元素定义过滤器;(2)使用过滤器。使用filter元素使用过滤器;(3)在代码中启用过滤器。前两个步骤都是在Hibernate的映射文件中完成的,其中filter-def是hibernate-mapping元素的子元素,而filter元素是class集合元素的子元素。filter-def元素用于定义一个过滤器,filter则将指定的过滤器应用到指定的持久化类。一个持久化类或集合可以使用多个过滤器,而一个过滤器也可以作用于多个持久化类或集合。看下面的映射文件示例:!DOCTYPE hibernate-mapp

3、ing PUBLIC -/Hibernate/Hibernate Mapping DTD 3.0/EN 在上面的配置文件中,定义了两个过滤器,过滤器的定义通过filter-def元素完成。定义过滤器时,只需要指定过滤器的名字,以及过滤器的参数即可。如Java里的一个方法声明,只有方法名和参数列表,具体的方法实现是没有的。过滤器的过滤条件是使用过滤器时才确定的,使用过滤器通过filter元素确定,filter的condition属性用于确定过滤条件,满足该条件的记录才会被抓取到。系统默认不启用过滤器,必须显式通过enableFilter(String filterName)才可以启用过滤器,该方

4、法返回一个Filter实例,Filter包含setParameter方法用于为过滤器参数赋值。一旦启用了过滤器,过滤器在整个Session内有效,所有的数据加载将自动应用该过滤条件,直到调用disableFilter方法。看下面的使用过滤器的示例代码:private void test() throws Exception /获取Hibernate Session对象 Session session = HibernateUtil.currentSession(); /开始事务 Transaction tx = session.beginTransaction(); /启用第一个过滤器 ses

5、sion.enableFilter(effectiveDate) /为过滤器设置参数 .setParameter(asOfDate, new Date(); /启动第二个过滤器 session.enableFilter(category) /为过滤器设置参数 .setParameter(catId, new Long(2); /执行查询,该查询没有任何的查询条件 Iterator results = session.createQuery(from Product as p) .iterate(); /遍历结果集 while (results.hasNext() Product p = (Pr

6、oduct)results.next(); System.out.println(p.getName(); /此处获取Product关联的种类,过滤器也将自动应用过滤 Iterator it = p.getCategories().iterator(); System.out.println(p.getCategories().size(); while (it.hasNext() Category c = (Category)it.next(); System.out.println(c.getName(); mit(); HibernateUtil.closeSession();通过使用过滤器定义常用的数据筛选规则,如果是临时的数据筛选,还是使用常规查询比较好。对于从前使用行列表达式视图的地方,此处可以考虑使用过滤器。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1