溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MyBatis之動(dòng)態(tài)SQL語(yǔ)句的示例分析

發(fā)布時(shí)間:2021-12-15 11:47:19 來(lái)源:億速云 閱讀:166 作者:小新 欄目:大數(shù)據(jù)

小編給大家分享一下MyBatis之動(dòng)態(tài)SQL語(yǔ)句的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

  動(dòng)態(tài)SQL語(yǔ)句簡(jiǎn)介

  動(dòng)態(tài)SQL語(yǔ)句是MyBatis的一個(gè)非常強(qiáng)大的功能,允許我們根據(jù)不同的需求,組合出不同的SQL語(yǔ)句,在select、update、insert、delete標(biāo)簽中都可以添加動(dòng)態(tài)SQL語(yǔ)句。

  IF標(biāo)簽

  IF標(biāo)簽可以在條件成立時(shí),在SQL語(yǔ)句中插入IF標(biāo)簽中的內(nèi)容,不成立就不插入

  示例:

  <select id="selectUserByUser" parameterType="User" resultMap="userMap">

  select * from tb_user where

  <if test="realname != null">

  u_realname=#{realname}

  </if>

  <if test="gender != null">

  and u_gender=#{gender}

  </if>

  </select>

  上面代碼中是按照User對(duì)象的各個(gè)屬性進(jìn)行查詢,如果姓名不為空就插入姓名作為條件,如果性別不為空就插入性別作為條件。

  但是我們會(huì)發(fā)現(xiàn)如果姓名為空,性別不為空,SQL語(yǔ)句就會(huì)變成:select * from tb_user where and u_gender=#{gender}

  或者姓名、性別都為空就會(huì)變成:select * from tb_user where

  這樣都會(huì)出現(xiàn)語(yǔ)法錯(cuò)誤,這樣我們就需要下一個(gè)標(biāo)簽:where

  Where標(biāo)簽

  Where標(biāo)簽 用于配置where條件,會(huì)去掉多余的and或or,如果一個(gè)條件都不成立,會(huì)自動(dòng)去掉sql中的where。

  代碼改為:

  <select id="selectUserByUser" parameterType="User" resultMap="userMap">

  select * from tb_user

  <where>

  <if test="realname != null">

  u_realname=#{realname}

  </if>

  <if test="gender != null">

  and u_gender=#{gender}

  </if>

  <if test="age != null">

  and u_age=#{age}

  </if>

  </where>

  </select>

  這樣就不會(huì)出現(xiàn)上面可能的錯(cuò)誤了

  Trim標(biāo)簽

  上面where標(biāo)簽的功能,也可以使用trim標(biāo)簽實(shí)現(xiàn),trim能去掉多余的前綴和后綴。

  語(yǔ)法:

  <trim prefix="前綴SQL" suffix="后綴" prefixOverrides="刪除前面的符號(hào)" suffixOverrides="刪除后面的符號(hào)">

  <if標(biāo)簽>

  </trim>

  示例:

  <trim prefix="where" prefixOverrides="and|or">

  ...

  </trim>

  Set標(biāo)簽

  用于配置update語(yǔ)句中的set部分,可以自動(dòng)添加set關(guān)鍵字,刪除多余的逗號(hào)

  示例:

  <update id="update" parameterType="User">

  update tb_user

  <set>

  <if test="name != null">

  u_name=#{name},

  </if>

  <if test="password != null">

  u_password=#{password},

  </if>

  </set>

  where u_id=#{id}

  </update>

  也可以使用trim實(shí)現(xiàn):

  <trim prefix="set" suffixOverrides=",">

  <if test="name != null">

  u_name=#{name},

  </if>

  ...

  </trim>

  Foreach標(biāo)簽

  用于循環(huán)遍歷集合或數(shù)組的值,如:按多個(gè)人姓名查詢

  select * from tb_user where u_realname in ('張三','李四'....)

  語(yǔ)法:

  <foreach collection="集合名" item="變量名" index="下標(biāo)名" open="開(kāi)始符號(hào)" close="結(jié)束符號(hào)" seperator="分割符號(hào)">

  #{變量名}

  </foreach>

  注意:集合名在Mapper接口中需要使用@Param注解配置

  示例:

  <select id="selectUserByRealnames" resultMap="userMap">

  select * from tb_user where u_realname in

  <foreach collection="realnames" item="name" index="i" separator="," open="(" close=")">

  #{name}

  </foreach>

  </select>

  Choose標(biāo)簽

  Java中有if,也會(huì)有if-else、switch語(yǔ)句來(lái)判斷多個(gè)條件,MyBatis也有Choose標(biāo)簽可以進(jìn)行多條件判斷

  示例:

  <select id="findActiveBlogLike"

  resultType="Blog">

  SELECT * FROM BLOG WHERE state = ‘ACTIVE’

  <choose>

  <when test="title != null">

  AND title like #{title}

  </when>

  <when test="author != null">

  AND author_name like #{author}

  </when>

  <otherwise>

  AND featured = 1

  </otherwise>

  </choose>

  </select>

  這里從第一個(gè)when進(jìn)行判斷,如果成立就插入條件,結(jié)束choose標(biāo)簽,如果不成立再判斷下一個(gè)when,如果所有when都不成立,就插入otherwise中的語(yǔ)句。

以上是“MyBatis之動(dòng)態(tài)SQL語(yǔ)句的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI