六、动态SQL


  • if (判断)
  • choose(分支选择)
    • when
    • otherwise
  • trim
    • where
    • set
  • foreach

if

  • test : 判断表达式(OGNL)
  • 从参数中取值判断

普通的

    <select id="findByParamIf" resultType="us" parameterType="us">
        SELECT * FROM users 
        WHERE
        <!-- test 判断表达式(OGNL表达式) -->
            <if test="uid!=null">
                uid=#{uid}
            </if>
            <!-- 并且不等于空字符串 (& >> &quot;) -->
            <if test="uname!=null and uname!=''">
                and uname = #{uname}
            </if>
            <if test="birthday!=null">
                and birthday=#{birthday}
            </if>
    </select>

<where>封装查询条件

<select id="findByParamIf" resultType="us" parameterType="us">
        <!-- 
            查询的时候,缺失第一个条件是会出现SQL拼错
            解决方法 一 :
                * 给where 加上 1=1 之后的条件都可以 and XXX=XXX 
            解决方法 二 :
                * 使用<where> Xxx = Xxx </where>
            -->
        SELECT * FROM users
        WHERE 1=1
        <!-- test 判断表达式(OGNL表达式) -->
            <if test="uid!=null">
                and uid=#{uid}
            </if>
            <!-- 并且不等于空字符串 (&:&quot;) -->
            <if test="uname!=null and uname!=''">
                and uname like #{uname}
            </if>
            <if test="birthday!=null">
                and birthday=#{birthday}
            </if>
    </select>

<trim>

  • prefix="" : 添加sql的前缀
  • prefixOverrides="" 指定去掉前边多余的字符串
  • suffix="" sql的后缀
  • suffixOverrides=""指定去掉后面多余的字符串

choose

  • 类似于分支语句 switch
    <!-- 查询 携带了哪个就只用哪个查(一次只能匹配一个参数) -->
    <select id="findByParamChoose" resultType="us" parameterType="us">
        SELECT * FROM users WHERE 1=1
            <!-- 只会选择一个参数查询 -->
            <choose>
                <!-- 第一步 -->
                <when test="uid!=null">
                    and uid=#{uid}
                </when>
                <!-- 第二步 -->
                <when test="uname!=null and uname!=''">
                    and uname like #{uname}
                </when>
                <otherwise>
                    <!-- 其他情况 -->
                </otherwise>
            </choose>
    </select>

set

  • 更新
  • 也可以使用trim 进行处理
    <!-- 修改 -->
    <update id="update" parameterType="us">
        <!-- 根据id 选择更新 -->
        UPDATE users
        <!-- 写更新的时候有可能多出逗号 -->
        <set>
            <if test="uname!=null">
                uname=#{uname},
            </if>
            <if test="birthday!=null">
                birthday=#{birthday},
            </if>
        </set>
        WHERE uid=#{uid}
    </update>

foreach

  • collection:指定输入对象中的集合属性的名称
  • item:每次遍历生成的对象
  • open:开始遍历时的拼接字符串
  • eparator:遍历对象之间需要拼接的字符串

范围查找

<!-- 动态 SQL 的另外一个常用的操作需求是对一个集合进行遍历,通常是在构建 IN 条件语句的时候(指定范围)
          用 foreach 来改写 select * from user where id in (1,2,3)
     -->
    <select id="findByParamForeach" resultType="us" parameterType="lsit">
        SELECT * FROM users  
        WHERE id 
        IN
        <!--
            collection:指定输入对象中的集合属性的名称
            item:每次遍历生成的对象
            open:开始遍历时的拼接字符串
            close:结束时拼接的字符串
            separator:遍历对象之间需要拼接的字符串
        -->
        <foreach collection="ids" item="id" open="(" separator="," close=")">
            id=#{id}
        </foreach>
    </select>

批量插入

  • 注意如果使用 ${ } 需要加 单引号 '${}'
<!-- 批量保存 -->
    <insert id="saveList">
    INSERT INTO test.users (uname, birthday) 
    VALUES
        <foreach collection="list" item="us" open="" separator="," close="">
            (#{us.uname} , #{us.showBirthday})
        </foreach>
    </insert>

参数

databaseId=""

  • 代表当前数据库的别名

配合if判断数据库
<if test="databaseId == "mysql">

parameter=""

  • 单个参数 : parameter就是这个参数
  • 多个参数 : 参数会被封装为一个map,parameter就代表这个map

配合if判断是否传入参数
<if test="parameter != null>

bind

  • 可以将OGNL表达式绑定到一个变量中,方便后来引用
  • 强行拼#{}的参数,(因为#{}是不可以拼字符串的),但是${}可以拼字符串(但是${}相对是不安全的,所以不建议使用)
<bind name="_uname" value="'%'+uname+'%'">

sqlinclude

  • sql抽取重复使用的sql语句片段
  • include插入指定的sql

声明

<sql id="insert_select">select * from</sql>

插入

<include refid="insert_select"/>
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容

  • 引言 动态SQL:Dynamic SQL。 本节我们来通过 MyBatis 的官方文档进行学习。 Descript...
    冯文议阅读 1,035评论 0 0
  • MyBatis 动态SQL 内容 Mybatis动态SQL在XML中支持的几种标签: if chose trim、...
    lihongyan阅读 8,363评论 1 10
  • 1. 简介 1.1 什么是 MyBatis ? MyBatis 是支持定制化 SQL、存储过程以及高级映射的优秀的...
    笨鸟慢飞阅读 5,474评论 0 4
  • 官网 中文版本 好的网站 Content-type: text/htmlBASH Section: User ...
    不排版阅读 4,380评论 0 5
  • pyspark.sql模块 模块上下文 Spark SQL和DataFrames的重要类: pyspark.sql...
    mpro阅读 9,449评论 0 13