JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課2-7:MyBatis參數(shù)傳遞_第1頁
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課2-7:MyBatis參數(shù)傳遞_第2頁
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課2-7:MyBatis參數(shù)傳遞_第3頁
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課2-7:MyBatis參數(shù)傳遞_第4頁
JavaEE企業(yè)級(jí)項(xiàng)目開發(fā)(第3版)課件 微課2-7:MyBatis參數(shù)傳遞_第5頁
已閱讀5頁,還剩10頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論