广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >MyBatis案例 | 使用映射配置文件实现CRUD操作——动态SQL优化条件查询
  • 756
分享到

MyBatis案例 | 使用映射配置文件实现CRUD操作——动态SQL优化条件查询

mybatissqljava 2023-09-09 15:09:29 756人浏览 薄情痞子
摘要

本专栏主要是记录学习完JavaSE后学习javaweb部分的一些知识点总结以及遇到的一些问题等,如果刚开始学习Java的小伙伴可以点击下方连接查看专栏 本专栏地址:🔥JavaWeb

本专栏主要是记录学习完JavaSE后学习javaweb部分的一些知识点总结以及遇到的一些问题等,如果刚开始学习Java的小伙伴可以点击下方连接查看专栏
本专栏地址:🔥JavaWeb
Java入门篇: 🔥Java基础学习篇
Java进阶学习篇(持续更新中):🔑Java进阶学习篇

在这里插入图片描述
本系列文章会将讲述有关于如何使用mybatis完成增删查改的操作,预计本系列文章会有以下这些文章,在写完本系列的文章后会有一篇文章罗列这些文章以及其地址(传送门)小伙伴们直接点击查看即可

文章名称文章地址
查询所有数据使用映射配置文件实现CRUD操作——查询所有数据
查询详情使用映射配置文件实现CRUD操作——通过主键查询对应数据
使用映射配置文件实现CRUD操作——多条件查询
添加数据
修改全部字段
修改动态字段
删除一条数据
批量删除数据

文章目录

一、前言

在上一篇文章中我们说到:单单使用参数占位符去编写sql语句还是存在一定的问题的,比如当我们有一个参数没有值的时候,就查询不出来结果了,而这种情况极有可能发生(因为用户不一定会筛选所有条件)所以要用动态SQL来解决问题

二、概述

在MyBatis中有以下几个属性标签来支撑动态SQL

  • if

  • choose(when,otherwise)

  • trim(where,set)

  • foreach

三、if标签(多条件动态查询)

1.概述

if标签是条件判断,if标签里面写test,即逻辑表达式,可以理解为if后面的判断语句

2.格式

<if test="···">···if>

3.具体实例

<select id="selectByCondition" resultMap="brandResultMap">        select        *        from tb_brand        where        <if test="status != null">            status = #{status}        if>        <if test="companyName != null and conpanyName != '' ">            and company_name like #{companyName}        if>        <if test="brandName != null and brandName != '' ">            and brand_name like #{brandName}        if>    select>

4.弊端

当我们stasus参数没有传入的时候,SQL语句会变化,变成一个不正确的SQL语句,如下所示,所以在查询过程中也会报错,无法正确实现查询要求,但是如果不加and的话,原本的SQL语句语法也不对,所以接下来会讲述如何解决
在这里插入图片描述

此时 SQL 语句

select * from tb_brand where and company_name like ? and brand_name like ?

5.解决弊端方法

1️⃣使用恒等式

这里我们只需要在where后加一个恒等式"1 = 1",那么就算第一个条件没有执行,SQL语句也不会出现语法错误,拼接完后的SQL语句会变成如下这样,也就不会报错,可以正常执行,但是依然不是最优解。MyBtais提供了一个where标签可以一下子解决问题

select * from tb_brand where 1 = 1 and company_name like ? and brand_name like ?

2️⃣使用where标签

这个标签可以 自动生成SQL语句中的WHERE关键字,并判断是否只有一个条件,如果是,还会 自动去掉AND,保证SQL语句的语法正确性
在这里插入图片描述

四、choose标签(单条件动态查询)

1.概述

choose标签是可以从多个条件中选择一个,可以把它看成Java中的switch语句,既然是要选择,那么每个条件都要有一个when标签包裹语句,如果所有条件都不符合的话,就要用otherwise标签来包裹最后的语句,一般为1 = 1,即直接查询所有的数据

一般会使用在单条件的动态查询中,比如下拉表单选择要查询的条件(状态/品牌名称/公司名称),再输入自己想要搜索的关键字

2.格式

<choose><when>···when><when>···when><otherwise>···otherwise>choose>

3.实例

<select id="selectByConditionSingle" resultMap="brandResultMap">        select *        from tb_brand        <where>       <choose>            <when test="status != null">                status = #{status}            when>            <when test="companyName != null and conpanyName != '' ">                company_name like #{companyName}            when>            <when test="brandName != null and brandName != '' ">                brand_name like #{brandName}            when>                        <otherwise>                1 = 1;            otherwise>        choose>where>select>

这里的测试类与前面相同,这里就不再赘述了,大家可以查看前面的文章来写测试类,这里我就传入了一个status参数来查询,即查询状态为1的数据,结果如下

[Brand{id=2, brandName=‘华为’, companyName=‘华为技术有限公司’, ordered=100, description=‘华为致力于把数字世界带入每个人、每个家庭、每个组织,构建万物互联的智能世界’, status=1}, Brand{id=3, brandName=‘小米’, companyName=‘小米科技有限公司’, ordered=50, description=‘are you ok’, status=1}]

如果没有任何一个参数传递进去的话,那么执行的会是1 = 1,那结果应该是表格中所有的数据
在这里插入图片描述

[Brand{id=1, brandName=‘三只松鼠’, companyName=‘三只松鼠股份有限公司’, ordered=5, description=‘好吃不上火’, status=0}, Brand{id=2, brandName=‘华为’, companyName=‘华为技术有限公司’, ordered=100, description=‘华为致力于把数字世界带入每个人、每个家庭、每个组织,构建万物互联的智能世界’, status=1}, Brand{id=3, brandName=‘小米’, companyName=‘小米科技有限公司’, ordered=50, description=‘are you ok’, status=1}]

五、结语

接下来将讲述添加功能,有任何问题可以留言评论

来源地址:https://blog.csdn.net/Alita233_/article/details/128890417

--结束END--

本文标题: MyBatis案例 | 使用映射配置文件实现CRUD操作——动态SQL优化条件查询

本文链接: https://www.lsjlt.com/news/401659.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作