MyBatis动态SQL--where 标签

在上一章中的介绍if 标签时,其实我们发现了一个问题,就是当所有条件都为空时,sql语句会多出来一个where,而且有时候会多出来一个and等等。

而where标签的作用就是为了解决这类问题,where 标签可以自动去除多余的where,and,or这类语句,它是专门管理where子句,可以使其更加灵活。

我们继续沿用上一章的if 标签基础上进行更改代码。

mapper接口如下:

//    动态sql--where 标签List<Book> findBookBySqlWhere(@Param("bname") String bname ,@Param("price") Double price ,@Param("cid") String cid ) ;

因为在上一章<if>标签中,已经对代码内容解释过了,所以这里就不在赘述代码了。

mapper映射文件的sql语句如下:

<!--    动态sql(where标签)--><select id="findBookBySqlWhere" resultType="com.feisi.mybatis.pojo.Book">select * from t_book<where><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></where>

这里其他的地方都没有改变,就是将原来的原生where改成了mybatis中的<where>标签,它管理着where标签里面的所有子句。

那么接下来我们对其进行测试代码如下:

 public void findBookBySqlWhereTest(){SqlSession sqlSession = SqlSessionUtil.openSession();BookMapper mapper = sqlSession.getMapper(BookMapper.class);
//        三个参数都为空时sql语句:select * from t_book
//        他会自动去掉多余出来的where
//        List<Book> books = mapper.findBookBySqlWhere("" ,null,"");//        第一不为空时的sql语句:select * from t_book WHERE bname like "%"?"%"
//        他会自动去掉第一个多余出来的andList<Book> books = mapper.findBookBySqlWhere("怡宝" ,null,"");for(Book book : books) System.out.println("查询到:"+book);sqlSession.close();}

 在上面的测试语句中可以看到,where标签已经帮我自动删除了多余的where,and,当然or也可以去除。

另外需要注意一点就是,where标签它只能去除写在前面的and,如果你把and语句写在后面,比如这样:

<if test="bname != null and bname != ''">bname like "%"#{bname}"%" and
</if>

 那么这样的话,where是不能去除多余的and的。

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

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

相关文章

Java基础 - 10 - File、IO流(一)

File&#xff1a;代表文本 IO流&#xff1a;读写数据 一. File File是java.io.包下的类&#xff0c;File类的对象&#xff0c;用于代表当前操作系统的文件&#xff08;可以是文件或文件夹&#xff09; 注意&#xff1a;File类只能对文件本身进行操作&#xff0c;不能读写文件里…

区块链技术的基本概念学习

1.去中心化 去中心化就是你我之间转账&#xff0c;不依赖于银行或支付处理公司。 2.区块链网络 区块链网络是由分布在全球的节点组成&#xff0c;每个节点都有完整的区块链副本。 3.区块 区块就是区块链中的的一个块&#xff0c;这个块里面包含了很多信息&#xff0c;如交…

搜维尔科技:TechViz 虚拟现实在工业项目中沉浸式体验

TechViz虚拟现实在工业项目中沉浸式体验 搜维尔科技&#xff1a;TechViz 虚拟现实在工业项目中沉浸式体验

Deepface Lab2.0参数选取建议

制作非常基本和低质量/分辨率的 Deepfakes 的最低要求&#xff1a; - 支持 AVX 和 SSE 指令的现代 4 核 CPU - 16GB RAM - 具有 8GB VRAM 的现代 Nvidia 或 AMD GPU - 充足的存储空间和大页面文件 确保启用硬件-加速 Windows 10/11 下的 GPU 调度并确保您的 GPU 驱动程序是最新…

MyBatis动态SQL--if 标签

mybatis动态sql对我们来说是非常常见的&#xff0c;比如在下面这样一个场景中&#xff0c; 我们需要多条件查询&#xff0c;但是查询的条件又不是固定的&#xff0c;是可以动态改变的&#xff0c;那我们就需要用到动态sql去完成。 动态SQL之 if 标签 接下来我们介绍第一个动态…

Day43 动态规划 part05

Day43 动态规划 part05 1049.最后一块石头的重量II 我的思路: 提示说和划分两个和相等的子集差不多&#xff0c;猛然想到&#xff0c;这道题不就是划分子集&#xff0c;用sum - 和最大*2 代码就是划分和相同的子集的变形 解答&#xff1a; class Solution {public int last…

【JavaScript】函数 ⑥ ( 使用 arguments 获取所有实参 | arguments 内置对象 | 伪数组概念 )

文章目录 一、使用 arguments 获取所有实参1、arguments 内置对象2、伪数组概念3、arguments 实参遍历4、arguments 代码示例 - 基本使用5、arguments 代码示例 - 遍历实参 一、使用 arguments 获取所有实参 1、arguments 内置对象 在 定义 JavaScript 函数 时 , 有时 不确定 形…

使用LangChain编写图检索查询实现RAG

大家好&#xff0c;检索增强生成&#xff08;Retrieval-Augmented Generation&#xff0c;简称RAG&#xff09;是一种先进的人工智能技术&#xff0c;通过整合大型语言模型&#xff08;LLM&#xff09;的内部知识和外部权威数据源&#xff0c;来提升生成式AI模型的表现。 本文…

安全可靠!麒麟信安操作系统各版本均不受liblzma/xz漏洞影响!

近日&#xff0c;XZ Utils 5.6.0和5.6.1版本存在严重后门风险的消息披露后&#xff0c;麒麟信安立即展开全面排查&#xff0c;经分析验证&#xff0c;麒麟信安操作系统各版本均不受liblzma/xz漏洞影响。 关于liblzma/xz漏洞 漏洞描述 xz 5.6.0 与 5.6.1 版本的上游代码中发现…

ComplexHeatmap绘图:注释、图例、热图基础(自备)

目录 基础介绍 Heatmap绘图基础参数 数据 作图参数 Heatmap Annotations&#xff08;注释&#xff09; 基础注释设置 简单注释测试 anno_points散点注释 anno_lines连线注释 anno_barplot条形图 anno_boxplot箱线图 anno_histogram直方图 热图组合 基础组合 进行…

【热门话题】文言一心与ChatGPT-4:一场跨时代智能对话系统的深度比较

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 文言一心与ChatGPT-4&#xff1a;一场跨时代智能对话系统的深度比较一、技术背景…

Maven--lib分离的打包方式

就是把lib包和source源码分开打包。优势就是&#xff0c;面对频繁更新的应用场景时&#xff0c;可以只更新源码包&#xff08;当然&#xff0c;前提是你的依赖没有增减&#xff09;。尤其是使用jenkins更新项目时&#xff0c;会省去很多时间吧&#xff1f; 不同项目的 lib之间不…

SQL语句生成器,支持MSSQL/MYSQL/SQLITE/ACCESS/EXCEL

经过7个月的艰苦开发&#xff0c;SQL语句生成器终于和各位见面了&#xff0c;因为工程量浩大&#xff0c;一度做到崩溃&#xff0c;差点烂尾&#xff0c;好在经过N次激烈思想斗争后还是坚持了下来累累累累累累累 本软件能够自动生成SQL语句及对应的易语言代码&#xff0c;还有相…

Golang vs Java

目录 前言 一、语言背景与特性 二、性能与效率 三、生态系统与库支持 四、开发体验与工具支持 五、微服务架构设计中的对比 六、总结与建议 前言 在当今的软件开发世界中&#xff0c;选择合适的编程语言对于项目的成功至关重要。GoLang&#xff08;也称为Golang&#x…

java入门第1课

最近想要入门一下java&#xff0c;目标很简单&#xff0c;就是学习Java的基本语法&#xff0c;内置数据结构&#xff1b;至于数据库啥的往后再说。由于是入门&#xff0c;所以就没有太难的东西&#xff0c;全都是基本的&#xff0c;还要个人吐槽&#xff0c;如果有错误的观点&a…

Yocto理论基础之定制镜像

Yocto理论基础之定制镜像 一、使用local.conf定制二、 使用IMAGE_FEATURES 和 EXTRA_IMAGE_FEATURES定制三、通过Custom .bb文件定制四、定制包组packagegroups五、定制系统名hostname 一、使用local.conf定制 最简单的方式就是通过conf/local.conf文件来定制image的组件&…

图片二维码如何制作生成?常规图片格式的二维码制作技巧

图片是展示信息很常用的一种方式&#xff0c;而现在查看图片很多人会通过二维码的形式来展现&#xff0c;这种方式优势在于更加的灵活&#xff0c;能够通过一个二维码展示大量的图片内容。那么图片二维码是如何制作生成的呢&#xff1f; 想要快速的将图片转二维码使用&#xf…

mapbox-gl扩展sprites图片

在mapbox-gl.js中&#xff0c;通过在styles中设置sprite和glyphs&#xff0c;实现样式图标和字体的加载。而一旦style加载完成&#xff0c;如果重置地图中的style&#xff0c;则会导致地图全部重新加载&#xff0c;图层的顺序&#xff0c;地图上的要素&#xff0c;都会丢失&…

智慧城市治理:构建全域覆盖的城市时空感知体系

TSINGSEE青犀AI算法中台是一款平台型产品&#xff0c;专注于提供各行业中小场景部署解决方案。平台具备接入广、性能强、支持跨平台、芯片国产化等特点&#xff0c;可提供丰富的视图接入能力和智能分析能力。 平台采用了多项IT高新技术&#xff0c;包括视频编解码技术、嵌入式…

成都直播基地出租:天府新区兴隆湖天府锋巢直播产业基地

天府新区兴隆湖天府锋巢直播产业基地&#xff0c;作为成都乃至西部地区的一颗璀璨明珠&#xff0c;正以其独特的魅力和无限的潜力&#xff0c;吸引着越来越多的目光。这里不仅是成都直播产业的聚集地&#xff0c;更是传统企业转型升级的摇篮&#xff0c;是新媒体时代下的创新高…