文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

MyBatis中怎么实现动态SQL!

2024-04-02 19:55

关注

这篇文章将为大家详细讲解有关MyBatis中怎么实现动态SQL!,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

一、if标签

if是最常用标签,经常用在判断语句上,可以实现某些简单的条件选择。基本使用示例如下:

<select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">        select * from user where 1=1        <if test="name != null and name != ''">            and name = #{name}        </if>        <if test="age != null ">            and age = #{age}        </if>    </select>

二、where标签

上面的例子中使用了“1=1”,是为了避免后续条件不满足时候报错,那有没有办法避免这种写法呢?

当然有,就是接下来要说的where,where标签会自动判断如果包含的标签中有返回值的话,就在sql中插入一个where,如果where标签最后返回的内容是以and  或者or开头的,也会被自动移除掉,上面例子中换成where标签后写法如下:

<select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">         select * from user          <where>             <if test="name != null and name != ''">                 and name = #{name}             </if>             <if test="age != null ">                 and age = #{age}             </if>         </where>     </select>

三、trim标签

trim的作用是去除特殊的字符串,它的prefix属性代表语句的前缀,prefixOverrides属性代表需要去除的哪些特殊字符串,prefixOverrides属性会忽略通过管道分隔的字符,后缀的处理和前缀一样。

trim标签的主要属性如下

举两个例子。

使用前缀属性

<select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">        select * from user        <trim prefix="WHERE" prefixOverrides="AND |OR " >            <if test="name != null and name != ''">                and name = #{name}            </if>            <if test="sex != null ">                or sex = #{sex}            </if>            <if test="age != null ">                and age = #{age}            </if>        </trim>    </select>

使用后缀属性

<update id="update" parameterType="Object">         UPDATE user         <trim prefix=" SET " prefixOverrides=",">             <if test="id != null ">,id=#{id}</if>             <if test="name != null ">,name=#{name}</if>             <if test="age != null ">,age=#{age}</if>         </trim>         WHERE ID=#{id}     </update>

四、foreach标签

foreach的作用是遍历集合,它能够很好地支持数组和List、Set接口的集合的遍历,往往和sql中的in组合比较多。

foreach标签的主要属性如下

举个例子:

<select id="queryAllUsersByName" resultType="com.example.springboot.mybatisxml.entity.User">         select * from user where id in         <foreach item="id" index="index" collection="userList"                  open="(" separator="," close=")">             #{id}         </foreach>     </select>

关于MyBatis中怎么实现动态SQL!就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯