4.动态SQL(if,choose,where,set,trim,foreach遍历)的使用+$和#的区别

文章目录

  • 动态sql
    • 一、动态sql
      • 1.if条件判断
      • 2、choose、when、otherwise
      • 3、where标签
      • 4、set标签
      • 5、`trim标签`
        • 1)替代where标签效果
        • 2) 生成set标签效果
      • 6、foreach迭代遍历
        • 1)属性
      • 7.`SQL`标签-提取重用的SQL代码片段
      • 8、bind标签
      • 9.MyBatis中`${}和#{}`的区别:

动态sql

一、动态sql

常见动态标签:

  • if
  • choose (when, otherwise)
  • trim (where, set)
  • foreach

1.if条件判断

if标签的test属性判断成立,就会将标签对之间的sql语句拼接到主sql语句上

//如果根据传入参数(emp_name和phone)筛选数据   
<select id="queryByNameAndTel" resultType="employee">
         select emp_name, phone, address, salary
         from employee
         where 1=1
         <if test="empName != null">
             AND emp_name = #{empName}
         </if>
         <if test="phone != null">
               and phone = #{phone}
         </if> 
     </select>

2、choose、when、otherwise

相当与java条件语句Switch语句

//根据多条件筛选语句  
<select id="queryByNameAndTel" resultType="employee">
         select emp_name, phone, address, salary
         from employee
         where 1=1
         <choose>
             <when test="empName != null">
                 and emp_name = #{empName}
             </when>
             <when test="phone != null">
                 and phone = #{phone}
             </when>
             <otherwise>
                 and dept_id = 1
             </otherwise>
         </choose>
     </select>

3、where标签

若子句的开头为 “AND” 或 “OR”,where 元素也会将它们去除。

     <select id="queryByNameAndTel" resultType="employee">
         select emp_name, phone, address, salary
         from employee
         <where>
             <if test="empName != null">
                 and emp_name = #{empName}
             </if>
             <if test="phone != null">
                 and phone = #{phone}
             </if>
         </where>
     </select>

4、set标签

用于动态更新语句的类似解决方案叫做 set,

动态更新需要更新的字段,忽略不更新的字段

 <update id="updateByPrimaryKeySelective">
         update employee
         <set>
             <if test="empName != null">
                 emp_name = #{empName},
             </if>
             <if test="phone != null">
                 phone = #{phone},
             </if>
             <if test="address != null">
                 address = #{address},
             </if>
             <if test="salary != null">
                 salary = #{salary}
             </if>
         </set>
         where id = #{id}
     </update>

5、trim标签

可以使用属性给sql语句添加前缀和后缀删除前缀和后缀

包含属性:

属性说明
prefix(添加前缀)添加前面的关键字(在标签开始位置,添加属性中的内容)
suffix(添加后缀)添加后面的关键字(在标签结束位置,添加属性中的内容)
prefixoverrides(删除前缀)去掉第一个关键字(所有子标签中第一子标签中的前缀关键字)
suffixoverrides(删除后缀)去掉最后一个关键字(所有子标签中最后一个子标签后缀的关键字)
1)替代where标签效果

prefix添加前缀where,代替where标签;prefixOverrides删除子语句判断条件的and | or

  <select id="queryByNameAndTel" resultType="employee">
         select emp_name, phone, address, salary
         from employee
         <trim prefix="where" prefixOverrides="AND|OR">
             <if test="empName != null">
                 and emp_name = #{empName}
             </if>
             <if test="phone != null">
                 and phone = #{phone}
             </if>
         </trim>
     </select>
2) 生成set标签效果

prefix添加前缀set替代set标签,suffixOverrides删除子语句尾部的,

<update id="updateByPrimaryKeySelective">
        update employee
        <trim prefix="set" suffixOverrides=",">
            <if test="empName != null">
                emp_name = #{empName},
            </if>
            <if test="phone != null">
                phone = #{phone},
            </if>
            <if test="address != null">
                address = #{address},
            </if>
            <if test="salary != null">
                salary = #{salary}
            </if>
        </trim>
        where id = #{id}
    </update>

6、foreach迭代遍历

应用于—批量插入或批量删除

1)属性
属性说明
collection集合的名字 默认为collection或者list ,可以通过@Param(“listName”)
item循环出的每个对象 在访问对象属性时,需要加前缀employee.id
open前缀
close后缀
separator以值进行分隔
index索引(当前迭代的序号)
<insert id="addBath">
        insert into dept values
        <foreach collection="deptList" item="dept" open="(" separator="),(" close=")">
          <!--属性值前加入前缀item值-->
            #{dept.deptId},#{dept.deptName},#{dept.remark}
        </foreach>
         <!--           或者这样写也可以
        <foreach collection="deptList" item="dept" separator=",">
         ( #{dept.deptId},#{dept.deptName},#{dept.remark})
       </foreach>
     -->
    </insert>

外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

7.SQL标签-提取重用的SQL代码片段

通过sql标签封装常使用的字段,通过include标签refid引用其id

 <sql id="base_column_sql">
        account_id ,account_no,account_name,balance
  </sql>
 <select id="queryByNo" resultMap="base-result-account">
        select
        <include refid="base_column_sql"/>
        from account
        where account_no = #{accountNo}
    </select>

8、bind标签

select id, dept_name as deptName, remark from dept where dept_name like #{dn}

9.MyBatis中${}和#{}的区别:

都是用于SQL语句中的占位符?

  1. #参数值直接替换到sql语句,并对参数进行类型转换和字符转义处理;可以有效防止SQL语句注入问题;
  2. $不会进行类型转换和字符转义处理,可能到值sql注入问题
模糊查询为例:
<select id="getBookByNname" resultType="com.example.demo.entity.BookInfo">
    select * from book_info where book_name like '${bookName}';
</select>

<select id="getBookByName" resultType="com.example.demo.entity.BookInfo">
    select * from book_info where book_name like concat('%',#{bookName},'%');
</select>

book_name like ‘${bookName}’;

select * from book_info where book_name like concat('%',#{bookName},'%'); ~~~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/784764.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

React -- useState状态更新异步特性——导致获取值为旧值的问题

useState状态异步更新 问题导致的原因解决办法进一步分析后续遇到的新问题 问题 const [isSelecting, setIsSelecting] useState(false);useEffect(() > {const handleKeyDown (event) > {if (event.key Escape) {if(isSelectingRef){//.......setIsSelecting(!isSele…

js使用proxy代理监听控制事件

本文为proxy代理的实例应用&#xff0c;有关代理的内容可以参考&#xff1a; js语法---理解反射Reflect对象和代理Proxy对象 监听事件 要监听dom元素的事件&#xff0c;我们会采用回调触发的方式来执行操作&#xff0c; 而触发事件的过程很明显是一个异步操作&#xff0c;异…

Oracle中EXIT Statement用于终止循环语句的关键字

Oracle的EXIT Statement是PL/SQL编程语言中用于终止循环语句的关键字。它有两种主要形式&#xff1a;无条件EXIT和条件EXIT WHEN。以下是对Oracle EXIT Statement的详细解释&#xff1a; 1. 无条件EXIT 语法&#xff1a;EXIT; 作用&#xff1a;无条件地终止当前循环。当程序执…

【咨询】企业数字档案馆(室)建设方案-模版范例

导读&#xff1a;本模版来源某国有大型医药行业集团企业数字档案馆&#xff08;室&#xff09;建设方案&#xff08;一期300W、二期250W&#xff09;&#xff0c;本人作为方案的主要参与者&#xff0c;总结其中要点给大家参考。 目录 1、一级提纲总览 2、项目概述 3、总体规…

办公必备——ONLYOFFICE8.1版本桌面编辑器

一、介绍ONLYOFFICE ONLYOFFICE是一款免费的开源办公软件&#xff0c;它可以让你创建、编辑和分享文档、表格和演示文稿。就像微软的Office一样&#xff0c;但它是完全免费的&#xff0c;而且可以在多种设备上使用&#xff0c;包括电脑和手机。它还支持多人同时在线编辑文档&am…

SpringCloud 负载均衡

目录 一、负载均衡 1、问题 2、什么是负载均衡 服务端负载均衡 客户端负载均衡 二、Spring Cloud LoadBalance 1、使用 Spring Cloud LoadBalance 2、负载均衡策略 3、LoadBalancer 原理 一、负载均衡 1、问题 我们来看一下前面写的代码&#xff1a; List<Serv…

抖音矩阵云剪系统saas源码 短视频矩阵获客管理系统

2024抖音矩阵云混剪系统是一款专业的短视频营销管理工具。该系统支持多平台多账号的集中式管理&#xff0c;并实现一键式作品发布功能。它配备了智能标题生成和关键词优化工具&#xff0c;以及排名查询机制&#xff0c;帮助用户提升内容在平台上更好的矩阵管理. 智能剪辑 托管发…

java中 使用数组实现需求小案例

Date: 2024.04.08 18:32:57 author: lijianzhan 需求实现&#xff1a; 设计一个java类&#xff0c;java方法&#xff0c;根据用户手动输入的绩点&#xff0c;从而获取到绩点最高的成绩。 实现业务逻辑的代码块 import java.util.Scanner;public class PointDemo {/*** 需求&…

Python 如何实现数据驱动的接口自动化测试

&#x1f345; 视频学习&#xff1a;文末有免费的配套视频可观看 &#x1f345; 点击文末小卡片&#xff0c;免费获取软件测试全套资料&#xff0c;资料在手&#xff0c;涨薪更快 大家在接口测试的过程中&#xff0c;很多时候会用到对CSV的读取操作&#xff0c;本文主要说明Pyt…

【Java]认识泛型

包装类 在Java中&#xff0c;由于基本类型不是继承自Object&#xff0c;为了在泛型代码中可以支持基本类型&#xff0c;Java给每个基本类型都对应了一个包装类型。 除了 Integer 和 Character&#xff0c; 其余基本类型的包装类都是首字母大写。 泛型 泛型是在JDK1.5引入的…

spring boot 3.x版本中集成spring security 6.x版本进行实现动态权限控制解决方案

一、背景 最近在进行项目从jdk8和spring boot 2.7.x版本技术架构向jdk17和spring boot 3.3.x版本的代码迁移&#xff0c;在迁移过程中&#xff0c;发现spring boot 3.3.x版本依赖的spring security版本已经升级6.x版本了&#xff0c;语法上和spring security 5.x版本有很多地方…

AntV X6 图编辑引擎速通

前言&#xff1a;参考 [AntV X6 官网](https://x6.antv.antgroup.com/) 一、简介 X6 可以快速搭建 DAG 图、ER 图、流程图、血缘图等应用。 二、快速上手 1. 安装 npm install antv/x6 --save# oryarn add antv/x6# orpnpm add antv/x6 2. 使用 2.1 初始画布 在页面中创…

【Linux进阶】文件系统3——目录树,挂载

前言 在Windows 系统重新安装之前&#xff0c;你可能会事先考虑&#xff0c;到底系统盘C盘要有多大容量&#xff1f;而数据盘D盘又要给多大容量等&#xff0c;然后实际安装的时候&#xff0c;你会发现其实C盘之前会有个100MB的分区被独立出来&#xff0c;所以实际上你就会有三个…

Java进阶----继承

继承 一.继承概述 继承是可以通过定义新的类&#xff0c;在已有类的基础上扩展属性和功能的一种技术. 案例&#xff1a;优化 猫、狗JavaBean类的设计 狗类&#xff1a;Dog 属性&#xff1a;名字 name&#xff0c;年龄 age 方法&#xff1a;看家 watchHome()&#xff0c;Gett…

QT5.12.9 通过MinGW64 / MinGW32 cmake编译Opencv4.5.1

一、安装前准备&#xff1a; 1.安装QT,QT5.12.9官方下载链接&#xff1a;https://download.qt.io/archive/qt/5.12/5.12.9/ QT安装教程&#xff1a;https://blog.csdn.net/Mark_md/article/details/108614209 如果电脑是64位就编译器选择MinGW64&#xff0c;32位就选择MinGW…

C#描述-计算机视觉OpenCV(5):直方图算法

C#描述-计算机视觉OpenCV&#xff08;5&#xff09;&#xff1a;直方图算法 前文链接图像直方图灰度直方图的计算灰度直方图的绘制BGR三通道的直方图直方图的均衡化算法相似图像检测 前文链接 文中没提到的东西&#xff0c;很可能都在前文描述过 C#描述-计算机视觉OpenCV&…

【C++深度探索】继承机制详解(二)

hello hello~ &#xff0c;这里是大耳朵土土垚~&#x1f496;&#x1f496; &#xff0c;欢迎大家点赞&#x1f973;&#x1f973;关注&#x1f4a5;&#x1f4a5;收藏&#x1f339;&#x1f339;&#x1f339; &#x1f4a5;个人主页&#xff1a;大耳朵土土垚的博客 &#x1…

深入解析:抖音视频标题的Python爬虫提取方法

引言 随着短视频的兴起&#xff0c;抖音已经成为全球最受欢迎的社交媒体平台之一。对于数据分析师、市场研究人员以及内容创作者来说&#xff0c;能够从抖音上抓取数据是一项宝贵的技能。本文将深入解析如何使用Python编写爬虫程序来提取抖音视频的标题。 爬虫基础 在开始编…

K8S 上部署大数据相关组件

文章目录 一、前言二、Redis 一、前言 Artifact Hub 是一个专注于云原生应用的集中式搜索和发布平台。它旨在简化开发者在 CNCF&#xff08;Cloud Native Computing Foundation&#xff09;项目中寻找、安装和分享包与配置的过程。用户可以通过这个平台方便地发现、安装各类云原…

为什么需要重写equals和如何重写equals

首先先看Java中的 &#xff0c;比较的两个对象的地址值。 如果是基本数据类型&#xff0c;那么就是比较的是值。 如果是引用数据类型&#xff0c;比较的就是地址. object类中的equals方法也是用的&#xff1b; 所以要比较两个对象的大小&#xff0c;去调用默认的equals方法…