亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

MyBatis深入解讀動(dòng)態(tài)SQL的實(shí)現(xiàn)

 更新時(shí)間:2022年04月27日 10:48:34   作者:羨羨ˇ  
動(dòng)態(tài) SQL 是 MyBatis 的強(qiáng)大特性之一。如果你使用過(guò) JDBC 或其它類(lèi)似的框架,你應(yīng)該能理解根據(jù)不同條件拼接 SQL 語(yǔ)句有多痛苦,例如拼接時(shí)要確保不能忘記添加必要的空格,還要注意去掉列表最后一個(gè)列名的逗號(hào)。利用動(dòng)態(tài) SQL,可以徹底擺脫這種痛苦

mybatis最強(qiáng)大的功能之一便是它的動(dòng)態(tài)sql能力

       借用官方文檔的一段話 : 如果您以前有使用JDBC或者類(lèi)似框架的 經(jīng)歷,您就會(huì)明白把SQL語(yǔ)句條件連接在一起是多么的痛苦,要確保不能忘記空格或者不要在 columns列后面省略一個(gè)逗號(hào)等。動(dòng)態(tài)語(yǔ)句能夠完全解決掉這些痛苦。

那么如果沒(méi)有這種功能到底有多痛苦呢 ? 我們來(lái)舉例說(shuō)明

       這是一張表 , 試想如果我們通過(guò) name 和 age來(lái)查詢表信息時(shí) , sql語(yǔ)句中肯定會(huì)存在 where和and字句 , 但是如果 name或者age 有一個(gè)為null或者都為null , 那么此時(shí)的 where 和and就會(huì)被孤立,那么這樣肯定會(huì)出現(xiàn)很多問(wèn)題 , 所以mybatis的動(dòng)態(tài)sql功能幫助我們完美解決

MyBatis 中用于實(shí)現(xiàn)動(dòng)態(tài) SQL 的元素主要有:

If   where   trim   set  choose(when, otherwise)   foreach

if和where

<select id="selectAllEmployee1" resultMap="employeeMap2" parameterType="Employee">
   SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
      LEFT JOIN dept d ON e.deptId = d.id
<where>
    <if test="name!=null &amp; name!=''">
         e.name =#{name}
    </if>
    <if test="age!=null &amp; age!=''">
         and e.age =#{age}
    </if>
</where>
</select>

使用這種標(biāo)簽 , 動(dòng)態(tài)sql可以根據(jù) 條件來(lái)自動(dòng)幫我們完善sql 

SqlSession sqlSession= MybatisUtil.getSqlSession();
EmployeeDao mapper=sqlSession.getMapper(EmployeeDao.class);
//創(chuàng)建一個(gè)對(duì)象,set值
Employee employee = new Employee();
employee.setName("");
employee.setAge(null);
List<Employee> employees = mapper.selectAllEmployee1(employee);
System.out.println(employees);
sqlSession.commit();
sqlSession.close();

第一次我們都設(shè)置null值, 表中數(shù)據(jù)完全被查詢

第二次我們只查詢年齡

employee.setName("");
employee.setAge(20);

查詢到兩條年齡為20的數(shù)據(jù) , 這就是mybatis動(dòng)態(tài)sql的強(qiáng)大之處

trim

上述的 where 與 if 我們也可以使用 trim 來(lái)代替where 

<select id="selectAllEmployee1" resultMap="employeeMap2" parameterType="Employee">
     SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
     LEFT JOIN dept d ON e.deptId = d.id
     <trim prefix="where" prefixOverrides="or|and">
        <if test="name!=null &amp; name!=''">
            e.name =#{name}
        </if>
        <if test="age!=null &amp; age!=''">
            and e.age =#{age}
        </if>
     </trim>
</select>

這里有兩個(gè)屬性 prefix , prefixOverrides

prefix : 代表前綴 , 如果if 中有成立的條件, 就會(huì)在sql前面拼入where字句

prefixOverrides :  根據(jù)if 條件自動(dòng)判斷是否去除 or | and字句

相應(yīng)的也有suffix與suffixOverrides , 代表對(duì)尾部的判斷

Choose

choose代表多路選擇(多選一)

<select id="selectAllEmployee1" resultMap="employeeMap2" parameterType="Employee">
        SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
        LEFT JOIN dept d ON e.deptId = d.id
        <trim prefix="where" prefixOverrides="or|and">
            <choose>
                <when test="name!=null &amp; name!=''">
                    and e.name =#{name}
                </when>
                <when test="age!=null">
                    and e.age =#{age}
                </when>
                <otherwise>
                    and e.name ='李雷'
                </otherwise>
            </choose>
        </trim>
    </select>

當(dāng)<when>中的條件成立時(shí), 走when中的語(yǔ)句,都不成立走<otherwise>

Set

set 可以根據(jù)條件自動(dòng)添加set字句,動(dòng)態(tài)更新列,也可以來(lái)剔除追加到條件末尾的任何不相關(guān)的逗號(hào)

<update id="updateEmployee">
        update employee
        <set>
            <if test="name!=null &amp; name!=''">
                name=#{name},
            </if>
            <if test="age!=null">
                age=#{age},
            </if>
        </set>
        where id=#{id}
    </update>

foreach

       <foreach> 主要用在構(gòu)建 in 條件中,它可以在 SQL 語(yǔ)句中進(jìn)行迭代一個(gè)集合。foreach元素的屬性主要有 item,index,collection,open,separator,close。 item 表示集合中每一個(gè)元素進(jìn)行迭代時(shí)的別名,index 指定一個(gè)名字,用于表示在迭代過(guò)程中,每次迭代到的位置,open 表示該語(yǔ)句以什么開(kāi)始, separator 表示在每次進(jìn)行迭代之間以什么符號(hào)作為分隔符,close 表示以什么結(jié)束,在使用 foreach 的時(shí)候最關(guān)鍵的也是最容易出錯(cuò)的就是 collection 屬性,該屬性是必須指定的,但是在不同情況下,該屬性的值是不一樣的。

– 如果傳入的是單參數(shù)且參數(shù)類(lèi)型是一個(gè) List 的時(shí)候,collection 屬 性值為 list

– 如果傳入的是單參數(shù)且參數(shù)類(lèi)型是一個(gè) array 數(shù)組的時(shí)候, collection 的屬性值為array

//創(chuàng)建一個(gè)list集合
List<Integer> list = new ArrayList<>();
list.add(19);
list.add(20);
List<Employee> employees = mapper.selectAllEmployee2(list);

接口方法如下 : 

  List<Employee> selectAllEmployee2(List<Integer> list);

對(duì)應(yīng)動(dòng)態(tài)sql如下 : 

<select id="selectAllEmployee2" resultMap="employeeMap2" parameterType="Employee">
        SELECT e.id,e.name ename,e.age,d.name dname FROM employee e
        LEFT JOIN dept d ON e.deptId = d.id where age in
        <foreach collection="list" item="age" open="(" separator="," close=")">
             #{age}
        </foreach>
    </select>

這里我們傳入的是一個(gè)集合, 所以參數(shù)選擇 list , 通過(guò)foreach我們可以動(dòng)態(tài)的根據(jù)集合里的值來(lái)查詢

關(guān)于動(dòng)態(tài)sql就介紹到這,感謝閱讀 !

到此這篇關(guān)于MyBatis深入解讀動(dòng)態(tài)SQL的實(shí)現(xiàn)的文章就介紹到這了,更多相關(guān)MyBatis動(dòng)態(tài)SQL內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • hadoop中實(shí)現(xiàn)java網(wǎng)絡(luò)爬蟲(chóng)(示例講解)

    hadoop中實(shí)現(xiàn)java網(wǎng)絡(luò)爬蟲(chóng)(示例講解)

    下面小編就為大家?guī)?lái)一篇hadoop中實(shí)現(xiàn)java網(wǎng)絡(luò)爬蟲(chóng)(示例講解)。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • 使用HandlerMethodArgumentResolver用于統(tǒng)一獲取當(dāng)前登錄用戶

    使用HandlerMethodArgumentResolver用于統(tǒng)一獲取當(dāng)前登錄用戶

    這篇文章主要介紹了使用HandlerMethodArgumentResolver用于統(tǒng)一獲取當(dāng)前登錄用戶實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • java 啟動(dòng)exe程序,傳遞參數(shù)和獲取參數(shù)操作

    java 啟動(dòng)exe程序,傳遞參數(shù)和獲取參數(shù)操作

    這篇文章主要介紹了java 啟動(dòng)exe程序,傳遞參數(shù)和獲取參數(shù)操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-01-01
  • java的反射用不好試試內(nèi)省?

    java的反射用不好試試內(nèi)省?

    使用內(nèi)省相對(duì)于直接使用反射更加安全可靠,Java的反射機(jī)制比較特殊,它不同于一般的編程方式,稍不小心就容易破壞類(lèi)的封裝性。練的不好,就容易走火入魔。沒(méi)關(guān)系,很多時(shí)候我們還可以使用Java的內(nèi)省機(jī)制哦
    2021-07-07
  • SpringBoot如何讀取resources目錄下的文件

    SpringBoot如何讀取resources目錄下的文件

    這篇文章主要介紹了SpringBoot如何讀取resources目錄下的文件問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Java 深入淺出掌握Map集合之雙列集合

    Java 深入淺出掌握Map集合之雙列集合

    雙列集合是每個(gè)元素都有鍵與值兩部分組成的集合,記錄的是鍵值對(duì)對(duì)應(yīng)關(guān)系,即通過(guò)鍵可以找到值,鍵必須是唯一,值可以重復(fù),接下來(lái)跟著小編具體了解吧
    2021-11-11
  • Servlet輸出一個(gè)驗(yàn)證碼圖片的實(shí)現(xiàn)方法實(shí)例

    Servlet輸出一個(gè)驗(yàn)證碼圖片的實(shí)現(xiàn)方法實(shí)例

    這篇文章主要給大家介紹了關(guān)于Servlet輸出一個(gè)驗(yàn)證碼圖片的實(shí)現(xiàn)方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-01-01
  • Java模擬實(shí)現(xiàn)ATM機(jī)

    Java模擬實(shí)現(xiàn)ATM機(jī)

    這篇文章主要為大家詳細(xì)介紹了Java模擬實(shí)現(xiàn)ATM機(jī),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • Spring Boot 2.7.6整合redis與低版本的區(qū)別

    Spring Boot 2.7.6整合redis與低版本的區(qū)別

    這篇文章主要介紹了Spring Boot 2.7.6整合redis與低版本的區(qū)別,文中補(bǔ)充介紹了SpringBoot各個(gè)版本使用Redis之間的區(qū)別實(shí)例講解,需要的朋友可以參考下
    2023-02-02
  • RocketMq消息隊(duì)列之削峰詳解

    RocketMq消息隊(duì)列之削峰詳解

    這篇文章主要介紹了RocketMq消息隊(duì)列之削峰詳解,MQ的主要特點(diǎn)為解耦、異步、削峰,本篇博客只是簡(jiǎn)單的記錄RocketMQ削峰用法,用于減少數(shù)據(jù)庫(kù)壓力的業(yè)務(wù)場(chǎng)景,需要的朋友可以參考下
    2023-09-09

最新評(píng)論