mybatis如何使用xml中的if-else/choose
最近需要使用 xml 文件來(lái)實(shí)現(xiàn)一些增刪改查,此文對(duì) 其中的 if-else 加以說(shuō)明
背景:
有一個(gè)引用類(lèi),假設(shè)叫 Student
public class Student {
private String name;
private String address;
private Integer yn;
}現(xiàn)在我們查詢條件也被封裝成一個(gè)引用類(lèi),例如:
public class StudentQueryModel {
private String name;
private String address;
private Integer pageIndex;
private Integer pageSize;
private Integer beginIndex;
}那么使用 xml 怎么來(lái)使用和接收呢?
首先肯定是在 mapper 里面有一個(gè)方法
List<Student> getStudentByCondition(@Param("s") StudentQueryModel model);然后在 xml 文件中寫(xiě)這個(gè)方法的具體實(shí)現(xiàn)
<select id="getStudentByCondition"
parameterType="入?yún)㈩?lèi)型,那么我們這里就應(yīng)該是 com.xxx.xxx.StudentQueryModel "
resultType="返回值類(lèi)型,注意,我們雖然查詢的是一些數(shù)據(jù),也就是List,但是這里不能寫(xiě) java.util.List 而是寫(xiě) com.xxx..xxx.Student ,如果只想查一條數(shù)據(jù),依舊是 com.xxx..xxx.Student ">
select * from t_student
WHERE
yn = 1
注意,這里最好不要用 <if></if> 標(biāo)簽,寫(xiě)不好就是坑很多,用 choose也是一樣的效果
<choose>
<when test=s.name != null and s.name != ''">
and t_student.name = #{s.name}
</when>
</choose>
<choose>
<when test="s.address != null and s.address != ''">
and t_student.address = #{s.address}
</when>
</choose>
limit #{s.beginIndex}, #{s.pageSize};//這里最好是在外面算出來(lái),在調(diào)用該方法之前就將這兩個(gè)值算好放到 model 中 不要在這里進(jìn)行加減乘除的運(yùn)算,弄不好也有坑
</select>到此這篇關(guān)于mybatis如何使用xml中的if-else/choose的文章就介紹到這了,更多相關(guān)mybatis使用xml if-else/choose內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
SSM框架下實(shí)現(xiàn)登錄注冊(cè)的示例代碼
這篇文章主要介紹了SSM框架下實(shí)現(xiàn)登錄注冊(cè)的示例代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
淺談Spring學(xué)習(xí)之request,session與globalSession作用域
這篇文章主要介紹了Spring學(xué)習(xí)之request,session與globalSession作用域的相關(guān)內(nèi)容,需要的朋友可以參考下。2017-09-09
SpringBoot3.3.X整合Mybatis-Plus的實(shí)現(xiàn)示例
本文介紹了在Spring Boot 3.3.2中整合MyBatis-Plus 3.5.7,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2025-03-03
Java直接輸出對(duì)象變成@.....的問(wèn)題及解決
這篇文章主要介紹了Java直接輸出對(duì)象變成@.....的問(wèn)題及解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
Java異常報(bào)錯(cuò):?java.io.IOException:?Broken?pipe解決方案
這篇文章主要介紹了Java異常報(bào)錯(cuò):java.io.IOException: Broken pipe的解決方案,java.io.IOException: Broken pipe是Java網(wǎng)絡(luò)編程中最常見(jiàn)的錯(cuò)誤之一,通常發(fā)生在客戶端和服務(wù)端之間的網(wǎng)絡(luò)連接異常斷開(kāi)時(shí),需要的朋友可以參考下2025-10-10
java實(shí)現(xiàn)的AES加密算法完整實(shí)例
這篇文章主要介紹了java實(shí)現(xiàn)的AES加密算法,結(jié)合完整實(shí)例形式分析了AES加密類(lèi)的實(shí)現(xiàn)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2016-07-07
JDK1.7 Paths,Files類(lèi)實(shí)現(xiàn)文件夾的復(fù)制與刪除的實(shí)例
下面小編就為大家分享一篇JDK1.7 Paths,Files類(lèi)實(shí)現(xiàn)文件夾的復(fù)制與刪除的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。以前跟隨小編過(guò)來(lái)看看吧2017-11-11

