`
terry0501
  • 浏览: 315743 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

Criterion 用法

阅读更多
方法
说明

Restrictions.eq


Restrictions.allEq
利用Map来进行多个等于的限制

Restrictions.gt


Restrictions.ge
>=

Restrictions.lt


Restrictions.le
<=
Restrictions.ne
<>

Restrictions.between
BETWEEN

Restrictions.like
LIKE

Restrictions.in
in

Restrictions.and
and

Restrictions.or
or

Restrictions.sqlRestriction
用SQL限定查询




有空再添加上,代码示例。



QBC常用限定方法

Restrictions.eq --> equal,等于.

Restrictions.allEq --> 参数为Map对象,使用key/value进行多个等于的比对,相当于多个Restrictions.eq的效果

Restrictions.gt --> great-than > 大于

Restrictions.ge --> great-equal >= 大于等于

Restrictions.lt --> less-than, < 小于

Restrictions.le --> less-equal <= 小于等于

Restrictions.between --> 对应SQL的between子句

Restrictions.like --> 对应SQL的LIKE子句

Restrictions.in --> 对应SQL的in子句

Restrictions.and --> and 关系

Restrictions.or --> or 关系

Restrictions.isNull --> 判断属性是否为空,为空则返回true

Restrictions.isNotNull --> 与isNull相反

Restrictions.sqlRestriction --> SQL限定的查询

Order.asc --> 根据传入的字段进行升序排序

Order.desc --> 根据传入的字段进行降序排序

MatchMode.EXACT --> 字符串精确匹配.相当于"like 'value'"

MatchMode.ANYWHERE --> 字符串在中间匹配.相当于"like '%value%'"

MatchMode.START --> 字符串在最前面的位置.相当于"like 'value%'"

MatchMode.END --> 字符串在最后面的位置.相当于"like '%value'"

例子
查询年龄在20-30岁之间的所有学生对象
List list = session.createCriteria(Student.class)
      .add(Restrictions.between("age",new Integer(20),new Integer(30)).list();
查询学生姓名在AAA,BBB,CCC之间的学生对象
String[] names = {"AAA","BBB","CCC"};
List list = session.createCriteria(Student.class)
      .add(Restrictions.in("name",names)).list();
查询年龄为空的学生对象
List list = session.createCriteria(Student.class)
      .add(Restrictions.isNull("age")).list();
查询年龄等于20或者年龄为空的学生对象
List list = session.createCriteria(Student.class)
      .add(Restrictions.or(Restrictions.eq("age",new Integer(20)),
                 Restrictions.isNull("age")).list();

--------------------------------------------------------------------
使用QBC实现动态查询
public List findStudents(String name,int age){

Criteria criteria = session.createCriteria(Student.class);
if(name != null){
  criteria.add(Restrictions.liek("name",name,MatchMode.ANYWHERE));
}
if(age != 0){
  criteria.add(Restrictions.eq("age",new Integer(age)));
}
criteria.addOrder(Order.asc("name"));//根据名字升序排列
return criteria.list();
}



-----------------------------------------------------------------------------------

今天用了写hibernate高级查询时用了Restrictions(当然Expression也是可以以的)这个类.感觉不错.
下面的代码写的不易读.其实核心就是一句
Restrictions.or(Restrictions.like(),Restrictions.or(Restrictions.like,........))
里面的or可以无限加的.还是比较好用

Session session = getHibernateTemplate().getSessionFactory()
                .openSession();
        Criteria criteria = session.createCriteria(Film.class);
        List<Film> list = criteria.add(
            Restrictions.or(Restrictions.like("description", key,MatchMode.ANYWHERE),
            Restrictions.or(Restrictions.like("name", key,MatchMode.ANYWHERE),
                Restrictions.or(    Restrictions.like("direct", key,MatchMode.ANYWHERE),
                Restrictions.or(Restrictions.like("mainplay",key,MatchMode.ANYWHERE),
                        Restrictions.like("filearea", key,MatchMode.ANYWHERE)))))).list();

        session.close();
        return list;
分享到:
评论

相关推荐

    criterion简介

    Criterion 的工作原理是将查询条件封装到一个 Criteria 对象中,然后使用 Session 的 createCriteria() 方法构建该对象。开发者可以使用 Criteria 的 add() 方法来添加查询条件,例如使用 Restrictions.eq() 方法来...

    hibernate_criterion.rar

    在这个例子中,我们创建了两个条件,然后使用`Restrictions.and()`方法将它们组合成一个"年龄大于等于18且状态为active"的查询条件。 最后,我们来谈谈Criterion的性能。由于Hibernate会将Criterion转换为SQL语句...

    Multi-Criterion Optimization

    文件中提到了多个学科分类号,如F.2, G.1.6, G.1.2, I.2.8等,这些分类号代表了论文集内容涉及的计算机科学领域,如计算逻辑、算法和数据结构、计算方法、人工智能等。这些分类有助于图书馆和研究人员对文献进行系统...

    Evolutionary Multi-Criterion Optimization

    1994年,Kalyanmoy Deb教授提出了NSGA(Non-dominated Sorting Genetic Algorithm),这是第一个被广泛接受和使用的进化多目标优化算法。随后,随着研究的深入和技术的进步,相继出现了多种改进版本,如NSGA-II、...

    使用make和criterion的CC++项目的项目设置工具。___.zip

    `Criterion`测试框架是针对C和C++的一个轻量级选择,它提供了一种结构化的断言方法和并发测试支持。它的设计目标是使编写测试尽可能简单,同时保持强大的功能。与传统的测试框架相比,`Criterion`提供了更好的错误...

    Hibernate中Criteria的完整用法.docx

    本文将对 Hibernate 中 Criteria 的用法进行总结,涵盖 Criteria 和 DetachedCriteria 的差异、Criterion 和 Projection 的使用方法等。 Hibernate 设计了 CriteriaSpecification 作为 Criteria 的父接口,下面提供...

    Hibernate Criteria用法大全.docx

    【Hibernate Criteria 用法详解】 Hibernate Criteria API 是一种面向对象的查询方式,它提供了一种比HQL(Hibernate Query Language)更为简洁且直观的查询手段。通过Criteria API,开发者可以构建复杂的查询条件...

    Hibernate - DetachedCriteria 的完整用法

    如使用 `session.createCriteria(Class)` 方法来创建 Criteria 实例,然后使用 `add(Criterion criterion)` 方法来添加查询条件,最后使用 `list()` 方法来获取查询结果。 Hibernate 的 Criteria 和 ...

    Hibernate的Criteria用法总结.doc

    Criterion 的实例可以通过 Restrictions 工具类来创建,Restrictions 提供了大量的静态方法,如 eq(等于)、ge(大于等于)、between 等来方法的创建 Criterion 查询条件(SimpleProjection 实例)。Example 的创建...

    论文研究-New Simple Early Stopping Criterion for LDPC Decoding Based on Variable-Node Message.pdf

    在LDPC码的译码过程中,通常使用迭代算法,即BP算法,这将涉及多次迭代直至找到正确的码字或达到最大迭代次数为止。每一次迭代都可能需要计算和更新所有变量节点和校验节点的信息。这个过程需要大量的计算资源和时间...

    Hibernate中Criteria的用法

    在上面的代码中,我们首先创建了一个 Criteria 对象,然后使用 `Restrictions.like()` 方法创建了一个条件对象,最后使用 `add()` 方法将条件添加到 Criteria 对象中,并使用 `list()` 方法来获取查询结果。...

    critcmp:用于比较Criterion运行的基准测试的命令行工具

    批判 用于比较Criterion运行的... 如果对Criterion内部格式进行了重大更改,则该项目将跟踪Criterion的最新版本,但是还将尝试在合理范围内继续使用较旧的版本。 例子 用法 除了提供作为位置参数的额外数据外,critcm

    奈奎斯特稳定判据Nyquist stability criterion

    奈奎斯特稳定判据是控制理论中的重要工具,它为闭环控制系统的稳定性分析提供了一种基于开环频率响应的方法。这一准则由美国学者哈里·奈奎斯特于1932年提出,是自动控制系统设计与分析的基石之一。奈奎斯特稳定判据...

    Hibernate中Criteria的完整用法

    Criterion 的实例可以通过 Restrictions 工具类来创建,Restrictions 提供了大量的静态方法,如 eq(等于)、ge(大于等于)、between 等来方法的创建 Criterion 查询条件(SimpleExpression 实例)。除此之外,...

    Criteria使用方法

    ### Criteria使用方法详解 #### 一、概述 在软件开发过程中,尤其是涉及到数据库操作的应用程序中,查询语言的灵活性和效率对于项目的成功至关重要。Hibernate作为Java领域中最流行的ORM(Object Relational ...

    hibernate criteria的使用方法

    ### Hibernate Criteria 使用方法详解 #### 一、简介 Hibernate 是一款非常流行的 Java 持久层框架,它简化了对象关系映射(ORM)过程中的许多复杂性。在 Hibernate 中,Criteria API 提供了一种类型安全的方式来...

    Entanglement detection beyond the CCNR criterion for infinite-dimensions

    要实现这个新的纠缠判据,需要使用到复杂数学和量子力学的知识,特别是关于Hilbert空间中的算子理论和矩阵分析。无限维Hilbert空间作为量子态的数学模型,为量子系统提供了一个连续无限的度量空间。Hilbert空间中的...

Global site tag (gtag.js) - Google Analytics