MyBatis中正则使用foreach拼接字符串

 更新时间:2022年01月14日 08:40:06   作者:weixin_42620197  
这篇文章主要介绍了MyBatis中正则使用foreach拼接字符串,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

正则使用foreach拼接字符串

业务需求:使用代理名字查询该代理的所有下级代理

数据库:

pid存储的是该字段的上级集合

在这里插入图片描述

实现步骤:

1、先用名字在用户表中查询出用户id集合

2、在数据库中判断字段pids中是否出现这些id,再去重

-------上重点-------:

在这里插入图片描述

在mybatis中写拼接这个sql碰到了很多坑,记录下这个教训:

1、foreach拼接字符串,开头和结尾用单引号,否则报错

2、中括号使用转义符,否则查询结果不正确

3、${item}不能用#,否则报错

4、使用replace函数去空格,否则查询不到结果(mybatis自动给我加上了空格)

foreach标签拼接多字段in ,和union

mybatis for标签 手写肯定是不可能,复制又经常忘记哪里有,记录一下复制方便

(oracle数据库)

批量添加 ,修改 ,拼接(xx,xx)in , union

添加,修改:

<foreach item="list" index="index" collection="list" open="begin" close="end;"> INSERT INTO XXX( xxx ) VALUES( #{list.XXX,jdbcType=VARCHAR}, #{xxx} //值不在list对象里,需要在mapper上加@param注解 ); </foreach>

(字段,字段) in :

(<foreach collection="paramList" index="index" item="item" open="(字段,字段,字段) in(" separator="," close=")"> <if test="index%900==0">(#{item.XX},#{item.XX},#{item.XXX})) or (XX,XX,XX) in(</if> (#{item.XX},#{item.XX},#{item.XX}) < /foreach> )

注意拼接in时 要用()包住for标签

union:
select a.xx xx
from(
    <foreach collection="query.list" item="item" separator="union all">
    select list.XX
    from XXX  list
    <where>
         list.XX= #{item} 
         < if test="query.xx!= null and query.xx!= ''">
        and list.xx= #{query.xx}
        < /if>
    < /where>
    </foreach>
    ) a
     order by a.xx

mysql数据库:

使用批量添加修改的时候需要在数据库地址加上: allowMultiQueries=true

url: jdbc:mysql://192.xxx.xx.xx:xxxx/test?useUnicode=true&characterEncoding=UTF-8&serverTimezone=Asia/Shanghai&allowMultiQueries=true

删除重复数据保留最大的id 

select *
FROM
    table AS ta
WHERE
    ta.id <> (
SELECT
    t.maxid
FROM
    ( SELECT max( tb.id ) AS maxid FROM table AS tb WHERE ta.job_id = tb.job_id ) t
    );

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • 解决Request.getParameter获取不到特殊字符bug问题

    解决Request.getParameter获取不到特殊字符bug问题

    这篇文章主要介绍了解决Request.getParameter获取不到特殊字符bug问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-07-07
  • 如何利用Spring Boot 监控 SQL 运行情况

    如何利用Spring Boot 监控 SQL 运行情况

    这篇文章主要介绍了如何利用Spring Boot监控SQL运行情况,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-07-07
  • Java for循环几种写法整理

    Java for循环几种写法整理

    这篇文章主要介绍了Java for循环几种写法整理的相关资料,需要的朋友可以参考下
    2017-02-02
  • SpringBoot使用MyBatis时的几种传参规范示例

    SpringBoot使用MyBatis时的几种传参规范示例

    使用Mybatis作为持久层框架时,对于数据库的增删改查等操作都需要参数的传递,本文就详细的介绍了一下SpringBoot使用MyBatis时的几种传参规范示例,感兴趣的可以了解一下
    2022-02-02
  • SpringBoot使用redis实现session共享功能

    SpringBoot使用redis实现session共享功能

    这篇文章主要介绍了pringboot项目使用redis实现session共享,文中通过代码示例讲解的非常详细,对大家的学习或工作有一定的帮助,需要的朋友可以参考下
    2024-05-05
  • Docker使用Dockerfile自定义镜像方式

    Docker使用Dockerfile自定义镜像方式

    这篇文章主要介绍了Docker使用Dockerfile自定义镜像方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-08-08
  • Spring中ClassPath指的是哪些地方

    Spring中ClassPath指的是哪些地方

    在Spring应用中,ClassPath指的是应用程序的类加载路径,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-06-06
  • Java迭代器实现Python中的range代码实例

    Java迭代器实现Python中的range代码实例

    这篇文章主要介绍了Java迭代器实现Python中的range代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • 一文总结Java获取文件后缀名的所有方法

    一文总结Java获取文件后缀名的所有方法

    Java是一种应用广泛的编程语言,可以通过多种方式来实现对文件的操作,如文件名后缀、文件扩展名等,下面这篇文章主要给大家介绍了关于Java获取文件后缀名的所有方法,需要的朋友可以参考下
    2023-05-05
  • mybatis if标签使用总结

    mybatis if标签使用总结

    这篇文章主要介绍了mybatis if标签使用总结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-12-12

最新评论