91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

MyBatis之動態SQL語句的示例分析

發布時間:2021-12-15 11:47:19 來源:億速云 閱讀:168 作者:小新 欄目:大數據

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

  動態SQL語句簡介

  動態SQL語句是MyBatis的一個非常強大的功能,允許我們根據不同的需求,組合出不同的SQL語句,在select、update、insert、delete標簽中都可以添加動態SQL語句。

  IF標簽

  IF標簽可以在條件成立時,在SQL語句中插入IF標簽中的內容,不成立就不插入

  示例:

  <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對象的各個屬性進行查詢,如果姓名不為空就插入姓名作為條件,如果性別不為空就插入性別作為條件。

  但是我們會發現如果姓名為空,性別不為空,SQL語句就會變成:select * from tb_user where and u_gender=#{gender}

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

  這樣都會出現語法錯誤,這樣我們就需要下一個標簽:where

  Where標簽

  Where標簽 用于配置where條件,會去掉多余的and或or,如果一個條件都不成立,會自動去掉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>

  這樣就不會出現上面可能的錯誤了

  Trim標簽

  上面where標簽的功能,也可以使用trim標簽實現,trim能去掉多余的前綴和后綴。

  語法:

  <trim prefix="前綴SQL" suffix="后綴" prefixOverrides="刪除前面的符號" suffixOverrides="刪除后面的符號">

  <if標簽>

  </trim>

  示例:

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

  ...

  </trim>

  Set標簽

  用于配置update語句中的set部分,可以自動添加set關鍵字,刪除多余的逗號

  示例:

  <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實現:

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

  <if test="name != null">

  u_name=#{name},

  </if>

  ...

  </trim>

  Foreach標簽

  用于循環遍歷集合或數組的值,如:按多個人姓名查詢

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

  語法:

  <foreach collection="集合名" item="變量名" index="下標名" open="開始符號" close="結束符號" seperator="分割符號">

  #{變量名}

  </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標簽

  Java中有if,也會有if-else、switch語句來判斷多個條件,MyBatis也有Choose標簽可以進行多條件判斷

  示例:

  <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>

  這里從第一個when進行判斷,如果成立就插入條件,結束choose標簽,如果不成立再判斷下一個when,如果所有when都不成立,就插入otherwise中的語句。

以上是“MyBatis之動態SQL語句的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

汉中市| 贵德县| 滨海县| 喀喇| 华亭县| 台南县| 乾安县| 伊吾县| 永丰县| 棋牌| 阜新市| 南平市| 乌拉特后旗| 大方县| 涞水县| 栾川县| 通榆县| 英超| 鹿泉市| 常山县| 炉霍县| 都兰县| 平南县| 正定县| 岳池县| 井研县| 普格县| 阿克苏市| 海原县| 耒阳市| 溧阳市| 额敏县| 岑溪市| 衢州市| 扶风县| 横峰县| 昭通市| 天镇县| 邛崃市| 徐水县| 武冈市|