• 8、动态SQL


    8、动态SQL

    8.1、什么是动态SQL

    在MyBatis框架中,动态SQL表示根据特定条件拼接SQL语句的功能,主要通过在映射文件中使用特定的标签来实现。

    8.2、if标签

    利用if标签可以进行简单的条件判断,从而进行SQL的拼接,但是漏洞比较大,

    
    <select id="selectByDynamicSQL" resultType="Student">
        select * from t_student where
        <if test="sId != null and sId != ''">
            s_id = #{sId}
        if>
        <if test="sName != null and sName != ''">
            and s_name = #{sName}
        if>
        <if test="sAge != null and sAge != ''">
            and s_age = #{sAge}
        if>
        <if test="sSex != null and sSex != ''">
            and s_sex = #{sSex}
        if>
    select>
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16

    比如条件全部成立,where就变得多余了。----解决---->利用where标签

    又比如第一个条件不成立其他条件成立,则又多出了一个and。 ----解决---->利用wheretrim标签解决。

    8.3、where标签

    利用where标签可以

    • 自动判断是否需要where语句,自动动态添加或删除。
    • 删除SQL语句之前的and或者or。

    在这里插入图片描述

    如果and或or在SQL语句后面该怎么动态增减?----->用trim标签。

    8.4、trim标签

    trim标签可以理解为where的升级版,这里的动态增加和动态删除是指SQL语句需不需要,确保SQL语句的正确性自动进行的动态增删。

    在这里插入图片描述

    8.5、choose|when|otherwise 标签

    choose|when|otherwise 是结合使用,类似于java中的switch|case|default

    在这里插入图片描述

    8.6、foreach标签

    foreach标签主要用于批量操作,例如批量删除、批量增加。

    根据SQL需要,设置separator|open|close等属性。

    1、批量删除

    在这里插入图片描述

    2、批量添加

    在这里插入图片描述

  • 相关阅读:
    Vue 快速入门之第四章 路由
    vscode路径别名文件跳转解决办法
    数据库设计流程---以案例熟悉
    Redis-Mysql八股总结
    搜索与推荐基础知识和es中间件
    Linux下安装Redis(单机版)
    List对象集合按照对象某一属性字段排序
    阿里云国际站如何进行实名登记?
    常见IO模型(非常详细)
    【CCIE 实验】BGP 13条选路原则实验
  • 原文地址:https://blog.csdn.net/weixin_48312484/article/details/125901654