Mybatis動態(tài)SQL的示例代碼
什么是動態(tài)SQL:動態(tài)SQL就是根據(jù)不同的條件生成不同的SQL語句
基本流程
1,數(shù)據(jù)庫準備一張表
2,導(dǎo)包
3,編寫核心配置文件
4,編寫實體類
5,編寫實體類對應(yīng)的Mapper和Mapper.xml文件
6,在核心配置文件中注冊Mapper.xml
7,測試
開啟自動駝峰命名規(guī)則映射
<!--開啟駝峰命名映射--> <setting name="mapUnderscoreToCamelCase" value="true"/>
即在數(shù)據(jù)庫中為create_time對應(yīng)Java實體類屬性createTime
IF,Where
<select id="queryListIf" parameterType="map" resultType="Blog"> select * from blog <where> <if test="title != null"> title = #{title} </if> <if test="author != null"> and author = #{author} </if> </where> </select>
Where的作用:當至少有一個滿足條件時添加Where,且會判斷后面加的第一條語句,若是and開頭,則會自動將這個and刪除
本質(zhì)上還是在拼接SQL,上述當沒有滿足條件時查詢blog表中的所有,當滿足條件時,則拼接SQL
Set
<update id="updateBlog" parameterType="map"> update blog <set> <if test="title != null"> title = #{title}, </if> <if test="author != null"> author = #{author} </if> </set> where id = #{id} </update>
Set的作用:至少有一個滿足條件時添加Set,且會判斷后面加的最后的語句,若是",“結(jié)尾,則會自動將這個”,"刪除
Choose(when,otherwise)
<select id="queryNoLimit" parameterType="map" resultType="Blog"> select * from blog <where> <choose> <when test="title != null"> title = #{title} </when> <when test="author != null"> and author = #{author} </when> <otherwise> and `view` = #{view} </otherwise> </choose> </where> </select>
choose(when,otherwise)類似與Java中的switch(case,default),choose進入選擇,when當什么什么時,進行條件判斷,若滿足條件,則執(zhí)行條件中的內(nèi)容,后面的when,otherwise將不再執(zhí)行,otherwise當所有when都不滿足條件時執(zhí)行
ForEach
<select id="queryBlogById" parameterType="map" resultType="blog"> select * from blog <where> <foreach collection="ids" item="id" open="(" close=")" separator="or"> id = #{id} </foreach> </where> </select>
上述為,一個集合ids存儲id的內(nèi)容,根據(jù)這個集合查詢所包含的id,open為開始,close為結(jié)束,separator為分隔符
才用map.put(“ids”,list)的方式導(dǎo)入集合
建議:現(xiàn)在Mysql中寫出完整的sql,再對應(yīng)的去修改即可
SQL片段
將一些功能的部分抽取出來方便復(fù)用
使用SQL標簽抽取公共的部分
<sql id="titleAuthor"> <if test="title != null"> title = #{title} </if> <if test="author != null"> and author = #{author} </if> </sql>
在需要的地方使用include標簽引用即可
<select id="queryListIf" parameterType="map" resultType="Blog"> select * from blog <where> <include refid="titleAuthor"></include> </where> </select>
注意事項:
1.最好基于單表來定義SQL片段
2.不要存在where標簽
總結(jié)
所謂的動態(tài)SQL就是在拼接SQL語句,我們只要保證SQL的正確性,按照SQL的格式去排列組合就可以了
到此這篇關(guān)于Mybatis動態(tài)SQL的示例代碼的文章就介紹到這了,更多相關(guān)Mybatis動態(tài)SQL內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Spring AOP手動實現(xiàn)簡單動態(tài)代理的代碼
今天小編就為大家分享一篇關(guān)于Spring AOP手動實現(xiàn)簡單動態(tài)代理的代碼,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2019-03-03Java使用poi實現(xiàn)excel的導(dǎo)入操作指南
使用Apache Poi是一種流行且廣泛使用的方式,可以幫助開發(fā)人員直接從Java代碼中讀取、寫入和處理Excel文件,因此在這篇文章我們將著重介紹如何實現(xiàn)excel的導(dǎo)入,感興趣的朋友可以跟著小編一起來學(xué)習(xí)2023-06-06List集合中對數(shù)據(jù)實現(xiàn)多重規(guī)則進行排序的案例
今天小編就為大家分享一篇關(guān)于List集合中對數(shù)據(jù)實現(xiàn)多重規(guī)則進行排序的案例,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧2018-12-12SpringMVC中controller接收json數(shù)據(jù)的方法
這篇文章主要為大家詳細介紹了SpringMVC中controller接收json數(shù)據(jù)的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-09-09Spring線程池ThreadPoolTaskExecutor配置詳情
本篇文章主要介紹了Spring線程池ThreadPoolTaskExecutor配置詳情,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03Java的SpringMVC中控制器返回XML數(shù)據(jù)問題
這篇文章主要介紹了Java的SpringMVC中控制器返回XML數(shù)據(jù)問題,控制器是處理HTTP請求的組件,它們接收來自客戶端的請求,并將其轉(zhuǎn)換為適當?shù)捻憫?yīng),這些響應(yīng)可以是動態(tài)生成的?HTML?頁面,也可以是JSON或XML格式的數(shù)據(jù),需要的朋友可以參考下2023-07-07SpringBoot整合EasyExcel?3.x的完整示例
EasyExcel 是一個基于 Java 的、快速、簡潔、解決大文件內(nèi)存溢出的 Excel 處理工具,它能讓你在不用考慮性能、內(nèi)存的等因素的情況下,快速完成 Excel 的讀、寫等功能,這篇文章主要介紹了SpringBoot整合EasyExcel3.x的過程,需要的朋友可以參考下2023-07-07基于Java實現(xiàn)一個簡單的單詞本Android App的實踐
本文基于Java實現(xiàn)了一個簡單的單詞本安卓app,用的是SQLite數(shù)據(jù)庫,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-01-01