MyBatis动态SQL--if 标签

mybatis动态sql对我们来说是非常常见的,比如在下面这样一个场景中,

我们需要多条件查询,但是查询的条件又不是固定的,是可以动态改变的,那我们就需要用到动态sql去完成。

动态SQL之 if 标签

接下来我们介绍第一个动态sql标签---< if > 标签.

我们模拟这样一个场景:有三个参数,这三个参数可以输入,也可以不输入,其中某个参数如果没有输入的话或者输入为空,这个参数就不加入sql语句的条件判断中。

mapper接口代码如下:

List<Book> findBookBySqlIf(@Param("bname") String bname ,@Param("price") Double price ,@Param("cid") String cid ) ;

这里顺便解释一下Param注解,因为这时多参数里面的内容。

Param注解作用:因为这里有多条参数,所以mybatis会将他们存进数组,当在编写sql语句时,我们获取这些参数的方式有三种方式。方式一:使用arg0,arg1...注意0就是第一个方式二:使用param1,param2...这里1是第一个参数但是这两种可读性都比较差,因为我在编写sql语句时,并不知道arg0或者param就是bname书名的意思。我还要回来看参数名才知道方式三:@Param("xxx")注解,写在对应的参数的前面,相当与给他取一个别名xxx,这样我们在编写sql语句的时候,就可以直接用见名知意的别名

mapper接口编写完成后,我们接下来在mapper映射文件中编写sql语句如下:

<select id="findBookBySqlIf" resultType="com.feisi.mybatis.pojo.Book">select * from t_book where 1=1<!--1.if标签的test属性时必须的,里面放着判断条件2.if标签中test属性的值是fasle或者true3.如果test中是true,则将if标签里面的sql语句拼接上去,否则跳过这个if标签中的slq语句4.在mybatis动态sql中并且用and--><!-- 这里的额判断条件就是参数不能为空,因为为空说明没有输入,那么要是加入sql语句的条件中,那么不管如果如何都查不到任何Book
--><if test="bname != null and bname != ''">and bname like "%"#{bname}"%"</if><if test="price != null and price != ''">and price>#{price}</if><if test="cid != null and cid != ''">and cid = #{cid}</if></select>

 从上面可以看出,if标签的作用就是对输入的参数进行判断,如果满足条件,就把if标签里的sql语句拼接起来 , 否则就跳过这段sql语句。主要为了防止输入的参数表空的时候,如果也把它加入sql语句的判断条件中,会导致查出来的数据为空。

     另外,这里获取参数的语句和前面Param注解呼应,如果前面没有加上Param注解起别名,那么这里的bname,price,cid都要写成arg0 ,arg1 , arg2 或者param1,2,3.。

     最后再来看看测试代码:

package com.feisi.testMybatis;import com.feisi.mybatis.mapper.BookMapper;
import com.feisi.mybatis.pojo.Book;
import com.feisi.mybatis.utils.SqlSessionUtil;
import org.apache.ibatis.session.SqlSession;
import org.junit.Test;import java.util.List;public class BookMapperTest {@Testpublic void findBookBySqlIfTest(){SqlSession sqlSession = SqlSessionUtil.openSession();BookMapper mapper = sqlSession.getMapper(BookMapper.class);
//        假设三个条件都不是空
//        List<Book> books = mapper.findBookBySqlIf("怡宝" ,99.0,"");
//        假设三个条件都是空
//        那么这里就会出现一个问题,因为三个都是空,那么条件全部都没有拼接上去,那么sql语句就变成了:
//        select * from t_book where
//        这样肯定是不行的,因为后面多了一个where,怎么解决呢?
//        我们可以在写sql语句的时候后面加一个恒true条件,比如这样写:
//        select * from t_book where 1=1 , 这样的话同时第一个if标签语句前面也要加上andList<Book> books = mapper.findBookBySqlIf("" ,null,"");for(Book book : books) System.out.println("查询到:"+book);sqlSession.close();}
}

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【fastadmin】脚本模式下,日志钩子函数执行出现死循环,导致内存溢出奔溃

问题出现原因是想对项目中error级别的日志&#xff0c;接入钉钉告警&#xff0c;方便查看 于是使用钩子方法&#xff0c;日志写入完成后&#xff0c;自动调用自定义的告警方法中 1、在application/tags.php 中添加log_write_done > [app\\common\\behavior\\Common, ],2、在…

2024 蓝桥打卡Day31

递归与辗转相除法 递归&#xff08;Recursion&#xff09;辗转相除法&#xff08;Euclidean Algorithm&#xff09;总结 递归&#xff08;Recursion&#xff09; 递归是指一个函数在执行过程中调用自身的过程。在编程中&#xff0c;递归函数在遇到满足某个条件时会停止调用自身…

苍穹外卖Day04套餐管理部分总结

写给像我一样完完全全的小白的。本人代码水平一塌糊涂&#xff0c;前几天就是机械地跟着视频敲代码。对于Day04的作业本来感觉代码抓瞎一点不会写&#xff0c;尽力去理解业务逻辑后发现好像也没那么难&#xff0c;整体代码可以仿照Day03新增菜品来进行实现&#xff01; 一、功…

关于简单又挣钱的冷门美团项目,美团圈圈

大家好&#xff0c;最近美团又开始搞事情了。接连推出了好几个网推项目&#xff0c;让一大波人都吃上了肉了。 美团的项目很简单&#xff0c;就是给它们的活动做推广。用户只需要拿到它推广的链接&#xff0c;然后去扫码进群就可以了。只要用户保持8天不退就行了。 下面是体验…

2024 ccfcsp认证打卡 2022 09 01 如此编码

2022 09 01 如此编码 题解1题解2 题解1 import java.util.Scanner;public class Main {public static void main(String[] args) {Scanner sc new Scanner(System.in);int n sc.nextInt(); // 天数int m sc.nextInt(); // 科目数int[] b new int[n 1]; // 存放结果的数…

剖析Linux内核的内存管理

大家好&#xff0c;今天给大家介绍剖析Linux内核的内存管理&#xff0c;文章末尾附有分享大家一个资料包&#xff0c;差不多150多G。里面学习内容、面经、项目都比较新也比较全&#xff01;可进群免费领取。 Linux内核的内存管理是一个复杂且关键的部分&#xff0c;它负责确保系…

MyBatis的基本应用

源码地址 01.MyBatis环境搭建 添加MyBatis的坐标 <!--mybatis坐标--><dependency><groupId>org.mybatis</groupId><artifactId>mybatis</artifactId><version>3.5.9</version></dependency><!--mysql驱动坐…

百卓Smart管理平台 importexport.php SQL注入漏洞复现(CVE-2024-27718)

0x01 产品简介 百卓Smart管理平台是北京百卓网络技术有限公司(以下简称百卓网络)的一款安全网关产品,是一家致力于构建下一代安全互联网的高科技企业。 0x02 漏洞概述 百卓Smart管理平台 importexport.php 接口处存在SQL注入漏洞,攻击者除了可以利用 SQL 注入漏洞获取数据…

Transformer的代码实现 day04(FFN)

前馈神经网络&#xff08;FFN&#xff09; 几个线性层、激活函数、归一化层的叠加 注意&#xff1a;归一化是在保持数据分布的前提下&#xff0c;将数据缩放到特定范围&#xff0c;方便运算。注意&#xff1a;标准化是让不同特征的数据保持相似的尺度&#xff0c;但是会改变数…

【CANN训练营笔记】Atlas 200I DK A2体验手写数字识别模型训练推理

环境介绍 开发板&#xff1a;Huawei Atals 200I DK A2 内存&#xff1a;4G NPU&#xff1a;Ascend 310B4 CANN&#xff1a;7.0 准备环境 下载编译好的torch_npu wget https://obs-9be7.obs.cn-east-2.myhuaweicloud.com/wanzutao/torch_npu-2.1.0rc1-cp39-cp39-linux_aarch…

python基础——模块【模块的介绍,模块的导入,自定义模块,*和__all__,__name__和__main__】

&#x1f4dd;前言&#xff1a; 这篇文章主要讲解一下python基础中的关于模块的导入&#xff1a; 1&#xff0c;模块的介绍 2&#xff0c;模块的导入方式 3&#xff0c;自定义模块 &#x1f3ac;个人简介&#xff1a;努力学习ing &#x1f4cb;个人专栏&#xff1a;C语言入门基…

Transformer的代码实现 day03(Positional Encoding)

Positional Encoding的理论部分 注意力机制是不含有位置信息&#xff0c;这也就表明&#xff1a;“我爱你”&#xff0c;“你爱我”这两者没有区别&#xff0c;而在现实世界中&#xff0c;这两者有区别。所以位置编码是在进行注意力计算之前&#xff0c;给输入加上一个位置信息…