Restrictions.like() 模糊查询,以及使用DetachedCriteria查询的一般用法

2016-10-10 16:52:38                                                 SSH框架学习                    共1899人围观                    0个不明物体                   

Restrictions.like() 模糊查询,以及使用DetachedCriteria查询的一般用法

今天测试一个搜索的模块用到模糊查询查询是否包含指定对象又因为使用到了分页

所以我们这里就使用了Restrictions.like() 来处理

这个方法有三个参数

如下

Restrictions.like(propertyName, value, matchMode)

第一个参数表示需要查询的字段名第二个参数表示需要匹配的数据第三个参数表示查询的精度默认是精确匹配相当于sql的 like 'value'

第三个参数是可选的

第一和第二个参数好理解主要是第三个参数他可以是以下的值

MatchMode.EXACT 精确匹配相当于 like 'value'
MatchMode.ANYWHERE 字符串在中间位置相当于 like '%value%'
MatchMode.START 字符串在最前面的位置相当于“like 'value%'
MatchMode.END 字符串在最后面的位置相当于“like '%value'

默认情况下是第一个精确匹配

如果你只想使用两个参数想实现后面的三种查询方法那我们就需要在参数中构造

如下面的代码

criteria.add(Restrictions.ilike("shopdes", "%"+stext+"%"));

也就是说上面的代码和下面的代码是一样的结果

criteria.add(Restrictions.ilike("shopdes", stext,MatchMode.ANYWHERE));

如果您的代码直接是这样

criteria.add(Restrictions.ilike("shopdes", stext));

那你的结果和上面的结果是不一样的哦这个是精准查找了不是模糊查找了

下面的代码也是一个意思

criteria.add(Restrictions.ilike("shopdes", stext+"%"));
criteria.add(Restrictions.ilike("shopdes", stext,MatchMode.START));

下面的代码也是一个意思

criteria.add(Restrictions.ilike("shopdes", "%"+stext));  criteria.add(Restrictions.ilike("shopdes", stext,MatchMode.END));

我们还可以这样进行组合模糊查询如下代码

criteria.add(Restrictions.or(Restrictions.like("shopdes", stext,MatchMode.ANYWHERE),Restrictions.like("shopname", stext)));

以上代码表示查询如果这个字符串和shopdes是模糊匹配或者和shopnama是精准匹配都符合我们的要求

关于DetachedCriteria的其他一些查询方法整理如下

Restrictions.eq() 这个就是比较和java的equalsleisi Restrictions.allEq() 参数为Map对象使用key/value进行多个等于的对比相当于多个Restrictions.eq()的效果 Restrictions.gt() 大于

Restrictions.ge() 大于等于 Restrictions.lt() 小于 Restrictions.le() 小于等于 Restrictions.between() 和SQL的between子句类似 Restrictions.in() 对应SQL的in子句 Restrictions.and() and关系 Restrictions.or() or关系 Restrictions.isNull() 判断属性是否为空为空返回true否则返回false Restrictions.isNotNull() 与Restrictions.isNull()相反 Order.asc() 根据传入的字段进行升序排序 Order.desc() 根据传入的字段进行降序排序

如果您觉得本文章对您有用也为了更好的运营博客您可以点击这里捐助

Restrictions.like() 模糊查询,以及使用DetachedCriteria查询的一般用法的更多相关文章

  1. 通过带参数的Sql语句来实现模糊查询(多条件查询)

    #region 通过带参数的Sql语句来实现模糊查询(多条件查询) StringBuilder sb = new StringBuilder("select * from books&quo ...

  2. NHibernate系列文章二十五:NHibernate查询之Query Over查询(附程序下载)

    摘要 这一篇文章介绍在NHibernate 3.2里引入的Query Over查询,Query Over查询跟Criteria查询类似.首先创建IQueryOver对象,然后通过调用该对象的API函数 ...

  3. Thinkphp查询 1.查询方式 2.表达式查询 3.快捷查询 4.区间查询 5.组合查询 6.统计查询 7.动态查询 8.SQL 查询

    1.使用字符串作为条件查询 $user = M('User'); var_dump($user->where('id=1 AND user="蜡笔小新"')->sele ...

  4. MySQL数据库6 -查询基础,简单查询,条件查询,对查询结果排序

    一.SELECT语句 SELECT COL1,COL2,....COLn FROM TABLE1,TABLE2,....TABLEn [WHERE CONDITIONS] -- 查询条件 [GROUP ...

  5. Atitit.Hibernate中Criteria 使用总结and 关联查询 and 按照子对象查询 o9o

    Atitit.Hibernate中Criteria 使用总结and 关联查询 and 按照子对象查询 o9o 1. Criteria,,Criterion ,, 1 <2. 主要的对象黑头配置磊 ...

  6. Atitit.列表页面and条件查询的实现最佳实践(1)------设置查询条件and提交查询and返回json数据

    Atitit.列表页面and条件查询的实现最佳实践(1)------设置查询条件and提交查询and返回json数据 1. 1. 配置条件字段@Conditional 1 1 2. 2. 配置条件字段 ...

  7. Hibernate之QBC查询与本地SQL查询

    1. QBC查询:     QBC 查询就是通过使用Hibernate提供的QueryByCriteria API 来查询对象,这种API封装了SQL语句的动态拼装,对查询提供了更加面向对象的功能接口 ...

  8. Atitit.Hibernate于Criteria 使用汇总and 关系查询 and 按照子对象查询 o9o

    Atitit.Hibernate于Criteria 使用总结and 关联查询 and 依照子对象查询 o9o 1. Criteria,,Criterion ,, 1 <2. 基本的对象黑头配置磊 ...

  9. MySQL数据库—查询基础,简单查询,条件查询,对查询结果排序

    一.SELECT语句 SELECT COL1,COL2,....COLn FROM TABLE1,TABLE2,....TABLEn [WHERE CONDITIONS] -- 查询条件 [GROUP ...

随机推荐

  1. C#获取当前站点的根地址

    /// <summary> /// 得到当前网站的根地址 /// </summary> /// <returns></returns> protecte ...

  2. SQL Server 索引维护:系统常见的索引问题

    在很多系统中,比如本人目前管理的数据库,索引经常被滥用,甚至使用DTA(数据库引擎优化顾问)来成批创建索引(DTA目前个人认为它的真正用处应该是在发现缺失的统计信息,在以前的项目中,用过一次DTA,里 ...

  3. BeanUtils简单应用

    <?xml version="1.0" encoding="UTF-8"?> <web-app xmlns:xsi="http:// ...

  4. 自定义JTabbedPane 标签风格

    自定义JTabbedPane 标签风格 2012年03月09日 20:33:12 阅读数:2435 demo 下载地址:http://download.csdn.net/detail/jinannan ...

  5. 9.python 系统批量运维管理器之Fabric模块

    前面介绍了paramiko,pexpect模块,今天来说比较适合大型应用自动化部署的模块,或者执行系统命令的模块Fabric. Fabric 是一个 Python 的库,同时它也是一个命令行工具.它提 ...

  6. 7. Smali基础语法总结

    最近在学习Android 移动安全逆向方面,逆向首先要看懂代码,Android4.4之前一直使用的是 Dalivk虚拟机,而Smali是用于Dalivk的反汇编程序的实现. Smali 支持注解,调试 ...

  7. input file 获取不到Request.Files 解决办法

    <input type="file" name="xxxxxxx"/>必须有“name”属性,否则在后台代码中用Request.Files是取不到值 ...

  8. 当鼠标悬停在链接上,或者点击过的链接,颜色会被设置为 #2a6496。同时,会呈现一条下划线。点击过的链接,会呈现一个颜色码为 #333 的细的虚线轮廓。另一条规则是设置轮廓为 5 像素宽,且对于基于 webkit 浏览器有一个 -webkit-focus-ring-color 的浏览器扩展。轮廓偏移设置为 -2 像素

    a:hover, a:focus { color: #2a6496; text-decoration: underline; } a:focus { outline: thin dotted #333 ...

  9. 01 git 概念

    本文转自“廖雪峰的git教程” 集中式版本控制系统:版本库是集中存放在中央服务器的,中央服务器就好比是一个图书馆,你要改一本书,必须先从图书馆借出来,然后回到家自己改,改完了,再放回图书馆. 分布式版 ...

  10. Selenium家谱

    自动化测试一词也算是整个测试行业里面比较热门的一个词儿,工资高,前景好,有实力,有态度等等,很多企业的管理者也在不断的扩大自己的队伍和职能,这也是导致自动化测试比较流行的原因之一.但是很多企业做自动化 ...