广告
返回顶部
首页 > 资讯 > 后端开发 > Python >Mybatis如何使用正则模糊匹配多个数据
  • 949
分享到

Mybatis如何使用正则模糊匹配多个数据

2024-04-02 19:04:59 949人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录使用正则模糊匹配多个数据背景mybaits正则匹配mybatis多字段模糊匹配同一个值CityDAOXML使用正则模糊匹配多个数据 背景 有这样一个需求,需要模糊匹配一个List

使用正则模糊匹配多个数据

背景

有这样一个需求,需要模糊匹配一个List<String>的所有元素,如果采用LIKE则需要写很多个语句,这时候其实可以采用正则匹配

mybaits正则匹配

Mysql模糊匹配姓名为a、b、c的所有学生

select * from table where name REGEXP 'a|b|c'

那么用mybatis怎么写呢?我们第一时间可能会这样写:

<select id="selectAll" resultMap="BaseResultMap" parameterType="java.util.List">
    select *
    from student
    where name REGEXP
    <foreach collection="list" item="item" open="'" close="'" separator="|">
            #{item}
    </foreach>
</select>

但这样是错误的,因为翻译sql,语句是

select * from student where name REGEXP ' ? | ? | ? '

不能在SQL语句中使用占位符?

正确的SQL应该是以下两种:

select * from student where name REGEXP ?
select * from student where name REGEXP CONCAT_WS('|',?,?,?)

对于前一个来说,占位符的数据应该在Java代码中拼接完成;对于后面一个,CONCAT_WS的参数应该在foreach标签中完成

<select id="selectAll" resultMap="BaseResultMap" parameterType="java.util.List">
    select *
    from student
    where name REGEXP CONCAT_WS('|',
    <foreach collection="list" item="item" open="" close="" separator=",">
        #{item}
    </foreach>
    )
</select>

Mybatis多字段模糊匹配同一个值

CityDAO

    List<Map<String, Object>> findByMap(Map<String, Object>map);
    List<Map<String, Object>> findByMap2(Map<String, Object>map);

XML

使用concat将多个字段拼接之后在进行模糊查询,相比第一种更推荐第二种,执行效率更好

  <select id="findByMap" resultType="java.util.Map">
        SELECT id,pid as pIDDD,city_name,type FROM city
        WHERE 1=1
        <if test="keyWord != null and keyWord != ''">
            AND pid LIKE concat('%',#{keyWord},'%')
            OR city_name LIKE concat('%',#{keyWord},'%')
            OR type LIKE concat('%',#{keyWord},'%')
        </if>
    </select>

    <select id="findByMap2" resultType="java.util.Map">
        SELECT id,pid as pIDDD,city_name,type FROM city
        WHERE 1=1
        <if test="keyWord != null and keyWord != ''">
            AND CONCAT(IFNULL(pid,''),IFNULL(city_name,''),IFNULL(type,'')) LIKE concat('%',#{keyWord},'%')
        </if>
    </select>

特别提醒:由于CONCAT中只要有一个为NULL,则会返回NULL,这将导致你查不到正确数据。为了确保不为NULL,使用 IFNULL判断下就可以了

IFNULL() 函数用于判断第一个表达式是否为 NULL,如果为 NULL 则返回第二个参数的值,如果不为 NULL 则返回第一个参数的值。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: Mybatis如何使用正则模糊匹配多个数据

本文链接: https://www.lsjlt.com/news/163227.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • Mybatis如何使用正则模糊匹配多个数据
    目录使用正则模糊匹配多个数据背景mybaits正则匹配Mybatis多字段模糊匹配同一个值CityDAOXML使用正则模糊匹配多个数据 背景 有这样一个需求,需要模糊匹配一个List...
    99+
    2022-11-13
  • 如何解决js正则匹配多个全部数据问题
    这篇文章给大家分享的是有关如何解决js正则匹配多个全部数据问题的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。需求:获取所有title里的内容正则表达式后面加g表示多次匹配方式一:...
    99+
    2022-10-19
  • PHP中的preg_match_all()函数:如何使用正则表达式匹配多个字符串
    PHP中的preg_match_all()函数:如何使用正则表达式匹配多个字符串,需要具体代码示例正则表达式是一种用来描述文本模式的工具,能够用来匹配、搜索或替换文本中符合某种模式的字符串。PHP中的preg_match_all()函数是一...
    99+
    2023-11-04
    PHP 正则表达式 preg_match_all()
  • 如何使用正则匹配最后一个字符串详解
    前几天遇到一个需求,输入的是 <user> <user> <name>a</name> </...
    99+
    2022-11-12
  • PHP的preg_match()函数:如何使用正则表达式匹配字符串
    PHP的preg_match()函数:如何使用正则表达式匹配字符串,需要具体代码示例正则表达式在字符串处理中是非常强大和灵活的工具。在PHP中,使用preg_match()函数可以方便地进行字符串的正则匹配,从而实现各种复杂的模式匹配和替换...
    99+
    2023-11-04
    正则表达式 匹配字符串 preg_match
  • 如何使用正则表达式对输入数字进行匹配详解
    目录前言:正文:总结前言: 最近有一个区间范围限制,一般255数字以下的都能在网上薅到,但是需要弄一个int16、int32、int64范围的输入限制......在网上逛了很久都没找...
    99+
    2022-11-13
  • 使用Mybatis如何实现删除多个数据
    目录Mybatis删除多个数据删除数据库中sid=1和sid=2的数据操作步骤如下Mybatis批量删除多表数据业务需求查询以obj_前缀开头的表的截断语句Mybatis删除多个数据...
    99+
    2022-11-13
  • 如何使用Mybatis如何实现删除多个数据
    这篇文章将为大家详细讲解有关如何使用Mybatis如何实现删除多个数据,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。Mybatis删除多个数据例如:删除数据库中sid=1和sid=2的数据操作步骤如下1....
    99+
    2023-06-29
  • 使用Spring如何实现配置多个数据源
    使用Spring如何实现配置多个数据源?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。配置两个不同的数据源,如下(由于项目使用的是druid数据库连接,配置可以会复杂点比较):&...
    99+
    2023-05-31
    spring 数据源
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作