乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      Java學(xué)習(xí)路線分享MyBatis之動(dòng)態(tài)SQL語(yǔ)句

       好程序員IT 2019-09-06

        Java學(xué)習(xí)路線分享MyBatis之動(dòng)態(tài)SQL語(yǔ)句,前言,我們?cè)谶M(jìn)行項(xiàng)目開(kāi)發(fā)時(shí),經(jīng)常遇到需要根據(jù)不同的需求,對(duì)原有SQL語(yǔ)句的內(nèi)容進(jìn)行修改,原來(lái)這是一個(gè)比較頭疼的問(wèn)題,因?yàn)樾枰獙?duì)原有SQL語(yǔ)句進(jìn)行拼接、重組,費(fèi)時(shí)費(fèi)力還容易出錯(cuò),今天我們將學(xué)習(xí)MyBatis的動(dòng)態(tài)SQL功能,可以解決這個(gè)問(wèn)題。

      動(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ǔ)句。

      總結(jié)

      動(dòng)態(tài)SQL語(yǔ)句是MyBatis非常重要的特性,能夠讓我們根據(jù)不同需求組合SQL語(yǔ)句,而且不容易出錯(cuò)。動(dòng)態(tài)SQL的標(biāo)簽有:if、where、set、choose、foreach等。掌握好它們我們可以寫(xiě)出更加靈活、高效的數(shù)據(jù)庫(kù)操作代碼。

        本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購(gòu)買(mǎi)等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
        轉(zhuǎn)藏 分享 獻(xiàn)花(0

        0條評(píng)論

        發(fā)表

        請(qǐng)遵守用戶 評(píng)論公約

        類(lèi)似文章 更多