




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
主講人:崔浩延遲符Mybatis中的參數(shù)傳遞MyBatis入門與配置Mybatis參數(shù)傳遞
單參數(shù)傳遞
順序傳參法
@Param注解傳參法
Map傳參法
JavaBean傳參法
集合類型傳參(以List類型為例)
@Param結(jié)合數(shù)組方式傳參單參數(shù)傳遞法MyBatis中進(jìn)行參數(shù)傳遞的一種方法是單參數(shù)傳遞。這意味著在Mapper接口方法中只傳遞一個(gè)參數(shù)。下面是單參數(shù)傳遞的示例:【例】單參數(shù)傳遞示例。定義Employee實(shí)體類@DatapublicclassEmployee{privateintid;privateStringname;privateStringdepartment;}EmployeeMapper接口publicinterfaceEmployeeMapper{List<Employee>getEmployeesByDepartment(Stringdepartment);}映射文件:EmployeeMapper.xml在EmployeeMapper.xml中,定義了一個(gè)查詢語句:<selectid="getEmployeesByDepartment"resultType="Employee">SELECT*FROMemployeesWHEREdepartment=#{department}</select>測(cè)試類在測(cè)試代碼中使用這個(gè)Mapper接口:List<Employee>employees=employeeMapper.getEmployeesByDepartment("IT");在這個(gè)例子中,getEmployeesByDepartment方法接收一個(gè)部門名稱作為參數(shù),然后在EmployeeMapper.xml中使用#{department}占位符將參數(shù)傳遞給SQL查詢。這樣就能根據(jù)部門名獲取相應(yīng)的員工信息。順序傳參法順序傳參法(Default)是MyBatis中一種簡單直接的參數(shù)傳遞方式,它按照參數(shù)在方法簽名中的順序來進(jìn)行參數(shù)傳遞。下面是順序傳參法的具體示例:【例】順序傳參示例。定義EmployeeMapper接口publicinterfaceEmployeeMapper{List<Employee>getEmployeesByDepartmentAndRole(Stringdepartment,Stringrole);}在這個(gè)接口中,getEmployeesByDepartmentAndRole方法接收兩個(gè)參數(shù),分別是部門(department)和角色(role)。映射文件:EmployeeMapper.xml在EmployeeMapper.xml中,定義了一個(gè)查詢語句:<selectid="getEmployeesByDepartmentAndRole"resultType="Employee">SELECT*FROMemployeesWHEREdepartment=#{arg0}ANDrole=#{arg1}</select>這里的#{arg0}表示第一個(gè)參數(shù),#{arg1}表示第二個(gè)參數(shù)。MyBatis會(huì)按照這個(gè)順序來進(jìn)行參數(shù)傳遞。測(cè)試類在測(cè)試代碼中使用這個(gè)Mapper接口:List<Employee>employees=employeeMapper.getEmployeesByDepartmentAndRole("IT","manager");在這個(gè)例子中,調(diào)用了getEmployeesByDepartmentAndRole方法,并傳遞了兩個(gè)參數(shù):"IT"和"manager"。MyBatis會(huì)將這兩個(gè)參數(shù)按照順序傳遞給SQL查詢語句中的占位符#{arg0}和#{arg1},從而完成參數(shù)傳遞和查詢操作。@Param注解傳參法@Param注解傳參法是MyBatis中一種常用的參數(shù)傳遞方式,它允許在Mapper接口方法中為每個(gè)參數(shù)指定一個(gè)名稱,并在XML中通過這些名稱來引用參數(shù)。下面是@Param注解傳參法的具體示例:【例】@Param注解傳參示例。EmployeeMapper接口publicinterfaceEmployeeMapper{List<Employee>getEmployeesByDepartmentAndRole(@Param("department")Stringdepartment,@Param("role")Stringrole);}在這個(gè)接口中,`getEmployeesByDepartmentAndRole`方法接收兩個(gè)參數(shù),分別是部門(department)和角色(role)。@Param注解用來指定參數(shù)的名稱。映射文件:EmployeeMapper.xml在EmployeeMapper.xml中,定義了一個(gè)查詢語句:<selectid="getEmployeesByDepartmentAndRole"resultType="Employee">SELECT*FROMemployeesWHEREdepartment=#{department}ANDrole=#{role}</select>在這個(gè)查詢語句中,使用了#{department}和#{role}這兩個(gè)占位符,它們分別對(duì)應(yīng)于方法中的@Param注解指定的參數(shù)名稱。@Param注解傳參法測(cè)試類最后,在Java代碼中使用這個(gè)Mapper接口:List<Employee>employees=employeeMapper.getEmployeesByDepartmentAndRole("IT","Manager");在這個(gè)例子中,調(diào)用了`getEmployeesByDepartmentAndRole`方法,并傳遞了兩個(gè)參數(shù):"IT"和"Manager"。在XML中,MyBatis會(huì)根據(jù)@Param注解指定的名稱將這兩個(gè)參數(shù)傳遞給查詢語句中對(duì)應(yīng)的占位符,從而完成參數(shù)傳遞和查詢操作。Map傳參法在MyBatis中,可以使用Map作為參數(shù)傳遞給Mapper接口方法,這種方式非常靈活,允許將多個(gè)參數(shù)打包成一個(gè)Map對(duì)象進(jìn)行傳遞。下面是Map傳參法的示例:【例】Map傳參示例。EmployeeMapper接口publicinterfaceEmployeeMapper{List<Employee>getEmployeesByParams(Map<String,Object>params);}在這個(gè)接口中,getEmployeesByParams方法接收一個(gè)Map類型的參數(shù),其中Map的key是參數(shù)的名稱,而value是對(duì)應(yīng)的值。映射文件:EmployeeMapper.xml在EmployeeMapper.xml中,定義了一個(gè)查詢語句:<selectid="getEmployeesByParams"resultType="Employee">SELECT*FROMemployeesWHEREdepartment=#{department}ANDrole=#{role}</select>在這個(gè)查詢語句中,使用了#{department}和#{role}這兩個(gè)占位符,它們分別對(duì)應(yīng)于Map中的key。Map傳參法測(cè)試類在測(cè)試代碼中使用這個(gè)Mapper接口:Map<String,Object>params=newHashMap<>();params.put("department","IT");params.put("role","manager");List<Employee>employees=employeeMapper.getEmployeesByParams(params);在這個(gè)例子中,創(chuàng)建了一個(gè)Map對(duì)象,并將部門(department)和角色(role)作為key-value對(duì)放入Map中,調(diào)用了getEmployeesByParams方法,并傳遞了這個(gè)Map對(duì)象作為參數(shù)。在XML中,MyBatis會(huì)根據(jù)Map中的key-value對(duì)將參數(shù)傳遞給查詢語句中對(duì)應(yīng)的占位符,從而完成參數(shù)傳遞和查詢操作。JavaBean傳參法在MyBatis中,可以使用JavaBean作為參數(shù)傳遞給Mapper接口方法,這種方式非常方便,尤其適用于參數(shù)較多或者參數(shù)之間存在復(fù)雜關(guān)系的情況。下面是JavaBean傳參法的示例:【例】JavaBean傳參示例。EmployeeSearchCriteria類作為JavaBean@DatapublicclassEmployeeSearchCriteria{privateStringdepartment;privateStringrole;}在這個(gè)JavaBean中,定義了部門(department)和角色(role)兩個(gè)屬性,并提供了相應(yīng)的getter和setter方法。EmployeeMapper接口publicinterfaceEmployeeMapper{List<Employee>getEmployeesByObject(EmployeeSearchCriteriacriteria);}在這個(gè)接口中,getEmployeesByObject方法接收一個(gè)EmployeeSearchCriteria類型的參數(shù),即我們剛剛定義的JavaBean。JavaBean傳參法映射文件:EmployeeMapper.xml在EmployeeMapper.xml中,定義了一個(gè)查詢語句:<selectid="getEmployeesByObject"resultType="Employee">SELECT*FROMemployeesWHEREdepartment=#{department}ANDrole=#{role}</select>在這個(gè)查詢語句中,使用了#{department}和#{role}這兩個(gè)占位符,它們分別對(duì)應(yīng)于EmployeeSearchCriteria中的department和role屬性。測(cè)試類在測(cè)試代碼中使用這個(gè)Mapper接口:EmployeeSearchCriteriacriteria=newEmployeeSearchCriteria();criteria.setDepartment("IT");criteria.setRole("manager");List<Employee>employees=employeeMapper.getEmployeesByObject(criteria);在這個(gè)例子中,創(chuàng)建了一個(gè)EmployeeSearchCriteria對(duì)象,并設(shè)置了部門(department)和角色(role)屬性。然后調(diào)用了`getEmployeesByObject`方法,并傳遞了這個(gè)對(duì)象作為參數(shù)。在XML中,MyBatis會(huì)根據(jù)JavaBean中的屬性值將參數(shù)傳遞給查詢語句中對(duì)應(yīng)的占位符,從而完成參數(shù)傳遞和查詢操作。集合類型傳參法(以List為例)在MyBatis中,可以使用集合類型作為參數(shù)傳遞給Mapper接口方法,這種方式適用于需要傳遞多個(gè)相同類型的參數(shù)的情況?!纠考项愋蛡鲄⑹纠?。EmployeeMapper接口publicinterfaceEmployeeMapper{List<Employee>getEmployeesByDepartmentList(List<String>departments);}在這個(gè)接口中,getEmployeesByDepartmentList方法接收一個(gè)List類型的參數(shù),其中List的元素是部門(department)的名稱。集合類型傳參法(以List為例)映射文件:EmployeeMapper.xml在EmployeeMapper.xml中,定義了一個(gè)查詢語句:<selectid="getEmployeesByDepartmentList"resultType="Employee">SELECT*FROMemployeesWHEREdepartmentIN<foreachitem="department"collection="list"open="("separator=","close=")">#{department}</foreach></select>在這個(gè)查詢語句中,使用<foreach>標(biāo)簽來遍歷List集合中的部門名稱,并將它們拼接成一個(gè)IN子句。測(cè)試類在測(cè)試代碼中使用這個(gè)Mapper接口:List<String>departments=Arrays.asList("IT","HR","Finance");List<Employee>employees=employeeMapper.getEmployeesByDepartmentList(departments);在這個(gè)例子中,創(chuàng)建了一個(gè)List對(duì)象,并將多個(gè)部門名稱作為元素放入List中。然后調(diào)用了getEmployeesByDepartmentList方法,并傳遞了這個(gè)List對(duì)象作為參數(shù)。MyBatis會(huì)根據(jù)List中的元素值將參數(shù)傳遞給查詢語句中對(duì)應(yīng)的占位符,從而完成參數(shù)傳遞和查詢操作。結(jié)合數(shù)組方式傳參法在MyBatis中,你可以使用數(shù)組作為參數(shù)傳遞給Mapper接口方法,結(jié)合@Param注解使用,這種方式與集合類型傳參類似,適用于需要傳遞多個(gè)相同類型的參數(shù)的情況?!纠緻Param注解結(jié)合數(shù)組傳參示例。EmployeeMapper接口publicinterfaceEmployeeMapper{List<Employee>getEmployeesByDepartmentArray(@Param("departments")String[]departments);}在這個(gè)接口中,getEmployeesByDepartmentArray方法接收一個(gè)String數(shù)組類型的參數(shù),其中數(shù)組的元素是部門(department)的
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2024年五年級(jí)英語上冊(cè) Unit 5 What does he do第四課時(shí)教學(xué)實(shí)錄 人教PEP
- 2024年五年級(jí)數(shù)學(xué)上冊(cè) 3 小數(shù)除法3課時(shí) 練習(xí)課配套教學(xué)實(shí)錄 新人教版
- 17 彩虹的形成 教學(xué)設(shè)計(jì)-2024-2025學(xué)年科學(xué)五年級(jí)上冊(cè)冀人版
- 三農(nóng)信息管理手冊(cè)
- 季度工作進(jìn)度計(jì)劃及實(shí)施方案
- 2023三年級(jí)英語上冊(cè) Module 6 Unit 2 How old are you教學(xué)實(shí)錄 外研版(三起)
- 2023一年級(jí)語文上冊(cè) 第四單元 口語交際:我們做朋友教學(xué)實(shí)錄 新人教版
- 2024-2025學(xué)年高中歷史 第三單元 第二次世界大戰(zhàn) 探究活動(dòng)課一 世界大戰(zhàn)的啟示-戰(zhàn)爭給人類帶來了什么教學(xué)教學(xué)實(shí)錄1 新人教版選修3
- 6 探訪古代文明(教學(xué)設(shè)計(jì))2023-2024學(xué)年統(tǒng)編版道德與法治 六年級(jí)下冊(cè)
- 12急行跳遠(yuǎn)教學(xué)設(shè)計(jì)8-八年級(jí)體育與健康
- 2025年合肥共達(dá)職業(yè)技術(shù)學(xué)院單招職業(yè)技能測(cè)試題庫附答案
- 2025美國急性冠脈綜合征(ACS)患者管理指南解讀課件
- 足球迷互動(dòng)活動(dòng)策劃與執(zhí)行策略
- 公司內(nèi)部辦公用品采購預(yù)算表
- 四川省南充市2025屆高三下學(xué)期高考適應(yīng)性考試(二診)語文試題(含答案)
- 湖北省2025屆高三下學(xué)期2月調(diào)考語文試題及參考答案
- 2025年湖南國防工業(yè)職業(yè)技術(shù)學(xué)院單招職業(yè)技能測(cè)試題庫完整版
- ESC+2024+心房顫動(dòng)(房顫)管理指南解讀
- 2025年《地陪導(dǎo)游服務(wù)程序》公開課標(biāo)準(zhǔn)教案
- 愛耳日完整課件
- 2025年國電投核能限公司招聘高頻重點(diǎn)模擬試卷提升(共500題附帶答案詳解)
評(píng)論
0/150
提交評(píng)論