关于Restrictions方法的说明,网上大部分不全,在此慢慢补全:
方法说明
方法
说明
Restrictions.eq
=
Restrictions.allEq
利用Map来进行多个等于的限制
Restrictions.gt
>
Restrictions.ge
>=
Restrictions.lt
<
Restrictions.le
<=
Restrictions.between
BETWEEN
Restrictions.like
LIKE
Restrictions.in
in
Restrictions.and
and
Restrictions.or
or
Restrictions.sqlRestriction
用SQL限定查询
2,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子句,闭区间xy中的任意值
Restrictions.like --> 对应SQL的LIKE子句
Restrictions.in --> 对应SQL的in子句
Restrictions.and --> and 关系
Restrictions.or --> or 关系
Restrictions.isNull --> 判断属性是否为空,为空则返回true
Restrictions.isNotNull --> 与isNull相反
Restrictions.sqlRestriction --> SQL限定的查询
Restrictions.not--> 传入qbe对象
criteria.add(Restrictions.not(Restrictions.eq("prodTypeId", prodTypeId)));
Restrictions.conjunction()-->逻辑与
Restrictions.disjunction()-->逻辑或
======================================================================
Restrictions.naturalId()-->对大多数查询,包括条件查询而言,因为查询缓存的失效(invalidation)发生得太频繁,查询缓存不是非常高效。然而,有一种特别的查询,可以通过不变的自然键优化缓存的失效算法。在某些应用中,这种类型的查询比较常见。条件查询API对这种用例提供了特别规约。
首先,你应该对你的entity使用<natural-id>来映射自然键,然后打开第二级缓存。
<class name="User">
<cache usage="read-write"/>
<id name="id">
<generator class="increment"/>
</id>
<natural-id>
<property name="name"/>
<property name="org"/>
</natural-id>
<property name="password"/>
</class>
注意,此功能对具有mutable自然键的entity并不适用。
然后,打开Hibernate 查询缓存。
现在,我们可以用Restrictions.naturalId()来使用更加高效的缓存算法。
session.createCriteria(User.class)
.add( Restrictions.naturalId()
.set("name", "gavin")
.set("org", "hb")
).setCacheable(true)
.uniqueResult();
======================================================================
======================================================================
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();
分享到:
相关推荐
Restrictions方法分页方法一些集合
Dynamic IP Restrictions: 保護 IIS 網站的流量守門員 iis 插件
PDF文档有时不能复制,粘贴,可能是因为屏蔽了复制功能,A-PDF Restrictions Remover可以解除这种屏蔽
A-pdf Restrictions Remover 是一款破解PDF密码限制的软件 这个事A-pdf Restrictions Remover 的破解版。。。 真绕口 把补丁rar解压到其他文件一起,然后用loadX或loadA,loadT(因系统而定)
"IP and domain restrictions" 是IIS提供的一个特性,提供了黑白名单,来限制用户对web资源的访问。由于没有合适的对比"IP and domain restriction" filtering list 与客户外部请求,导致攻击者可以构造特定的请求...
NULL 博文链接:https://caohong286.iteye.com/blog/1332905
Quantum Complexity restrictions on algorithms and architectures 【PhD 】
。。。
。。。
去除PDF 文件不让打印
受多项式限制的和集新扩展,周岳,,通过取Morris等式的首项和次高项系数,本文得到了一些新的多项式系数。利用这些系数并运用N. Alon的多项式方法得到了受多项式限制的和�
Smoothing and Regression Approaches, Computation, and Application
iOS-限制-Cracker-Linux ... 它可以使用不限数量的线程来完成此过程。... ./restrictions-crack "J94ZcXHm1J/F9Vye8GwNh1HNclA=" "/RHN4A==" Docker的用法 从docker.com安装Docker 克隆此存储库 cd进入存储库 运行docker
github-merge-restrictions
并且通过菜单选择,只...A-PDF Restrictions Remover 简单易用并且集成到了 Windows 操作系统的上下文关联右键点击菜单当中,允许你清除所选择文件的限制,或者创建一个清除限制文件的拷贝从而保持原始文件完整无缺。
FixUp Restrictions 可以恢复您的任务管理器、注册表编辑器、文件夹选项、搜索选项、隐藏驱动器、运行选项、显示隐藏文件和文件夹等选项,它可以帮助您从 Windows 注册表和文件系统中删除病毒的影响。
7-Zip压缩软件7-Zip is open source software. Most of the source code is under the ... The unRAR code is under a mixed license: GNU LGPL + unRAR restrictions. Check license information here: 7-Zip license.
Oracle_start_with_connect_by_prior_用法[文].pdf
BO软件语义层Universe的官方培训教材的第一部分
photoscan-软件说明书able of Contents Overview ......................................................................................................................... iv How it works ...................