SpringBoot使用MyBatis時(shí)的幾種傳參規(guī)范示例
使用Mybatis作為持久層框架時(shí),對(duì)于數(shù)據(jù)庫的增刪改查等操作都需要參數(shù)的傳遞,這里學(xué)習(xí)記錄一下MyBatis中可用的參數(shù)傳遞方式。
1. 單個(gè)簡(jiǎn)單參數(shù)傳遞
使用 MyBatis 傳遞單個(gè)參數(shù)時(shí)比較簡(jiǎn)單,形式如#{a}
,#
,#{param1}
等都可以在 MyBatis 中獲取到唯一參數(shù),但是參數(shù)名盡量和入?yún)⒚恢?,這樣更符合開發(fā)規(guī)范。
Mapper 文件定義
UserInfo selectById(String userId);
xml 文件定義
- 單個(gè)參數(shù)時(shí),標(biāo)簽中可不定義參數(shù)類型
<select id="selectByUserId" resultType="com.shone.entity.UserInfo"> select user_id, user_name from user_info where user_id=#{userId} </select>
2. 匿名參數(shù)順序傳遞
匿名參數(shù)傳遞時(shí)使用的是 MyBatis 中索引傳遞的方式,對(duì)于傳遞的多個(gè)參數(shù),在sql
語句標(biāo)簽中使用#{param1}
、#{param2}
等索引依次代表傳入的參數(shù)值。
Mapper 文件
- 使用匿名參數(shù)傳遞時(shí),接口中定義的方法參數(shù)無需使用注解
UserInfo selectByNameAndAge(String userName, Integer age);
xml 文件
- xml中讀取參數(shù)時(shí)可以使用使用arg0, arg1, param1, param2等形式
- 參數(shù)有多個(gè)類型且匿名,因此不需要指定入?yún)㈩愋?/li>
- Mapper中沒有使用注解,因此直接使用參數(shù)名時(shí)會(huì)報(bào)錯(cuò)參數(shù)名找不到
<select id="selectByNameAndAge" resultType="com.shone.entity.UserInfo"> select user_id, user_name from user_info where user_name=#{param1} and user_gender=#{param2} </select>
- 匿名參數(shù)傳遞方法可讀性差,對(duì)后期維護(hù)不友好,不符合開發(fā)規(guī)范。
3. 使用@Param注解傳遞
@Param注解用于指定key,指定了key之后,在sql
標(biāo)簽中可以使用key來索引對(duì)應(yīng)的參數(shù)值。
Mapper 文件
- 接口中定義時(shí)使用 @Param注解指定參數(shù)對(duì)應(yīng)的key
UserInfo selectByNameAndAge(@Param("userName") String userName, @Param("age") Integer age);
xml 文件
- 不需要指定傳入?yún)?shù)類型
- 使用注解指定的key就可以獲取到對(duì)應(yīng)入?yún)⒅?/li>
<select id="selectByNameAndAge" resultType="com.shone.entity.UserInfo"> select user_id, user_name from user_info where user_name=#{userName} and user_gender=#{age} </select>
@Param注解傳參使用時(shí)清晰簡(jiǎn)潔明了,符合開發(fā)規(guī)范,在參數(shù)較少時(shí)建議使用該方式。
4. 使用Map傳遞參數(shù)
MyBatis框架底層就是將入?yún)⑥D(zhuǎn)換成Map類型進(jìn)行傳遞的,因此我們也可以使用Map進(jìn)行參數(shù)的傳遞,傳入的參數(shù)在sql
標(biāo)簽中可以根據(jù)Map中的key值直接獲取。
使用時(shí),需要將傳入的參數(shù)放入到map中
map.put("userName","tom"); map.put("gender",1);
Mapper 文件
UserInfo selectByNameAndAge(Map<String, Object> map);
xml 文件
- 入?yún)㈩愋椭付镸ap
<select id="selectByNameAndAge" resultType="com.shone.entity.UserInfo" paramterType="map"> select user_id, user_name from user_info where user_name=#{userName} and user_gender=#{age} </select>
使用Map傳遞參數(shù)符合MyBatis底層的設(shè)計(jì),性能也沒有問題,但是在開發(fā)中由于將所有值封裝成為map,無法直觀看到map中可能含有的參數(shù),在后期維護(hù)上不太友好。
5. 使用JavaBean(POJO)傳遞
除了Map方式,還可以使用JavaBean的方式來傳遞多個(gè)參數(shù),此時(shí)在sql
標(biāo)簽中直接使用bean對(duì)象的屬性來索引參數(shù)值,注意bean對(duì)象中 需要有相應(yīng)參數(shù)的get
方法,否則無法正常獲取。
使用javabean作為參數(shù),需要先定義JavaBean
@Data public class UserInfo { private String userName; private Integer age; }
Mapper 文件
UserInfo selectByEntity(UserInfo userInfo);
xml 文件
- 指定入?yún)㈩愋蜑橄鄳?yīng)的JavaBean全路徑限定類名
<select id="selectByNameAndAge" resultType="com.shone.entity.UserInfo" paramterType="com.shone.entity.UserInfo"> select user_id, user_name from user_info where user_name=#{userName} and user_gender=#{age} </select>
JavaBean的參數(shù)傳遞方式更符合項(xiàng)目開發(fā)的規(guī)范,實(shí)際使用時(shí)簡(jiǎn)潔明了,在參數(shù)較多時(shí)建議使用這種方式,創(chuàng)建JavaBean來作為參數(shù)傳遞對(duì)象。
6. 使用List、Array、Set傳遞
List、Array、Set等方式的傳參通常用于sql
標(biāo)簽中的in操作,即用于MyBatis中的標(biāo)簽。
使用list或array時(shí),一般是做in操作,只有一個(gè)參數(shù)。
Mapper 文件
UserInfo selectByIdList(List<String> userIdList);
xml 文件
- 不需要指定入?yún)㈩愋?,或指定為List
- 使用標(biāo)簽處理sql中的in操作
- 如果參數(shù)是list,則collection為list;如果參數(shù)類型是array,則collection是array
- 如果是多個(gè)參數(shù)或者是對(duì)象的屬性值作為list,則傳參應(yīng)為map/bean類型,collection應(yīng)為對(duì)象屬性中的list
<select id="selectByIdList" resultMap="userResultMap"> select * from user_info where status=1 and user_id in <foreach collection="list" item="item" open="(" separator="," close=")"> #{item} </foreach> </select>
到此這篇關(guān)于SpringBoot使用MyBatis時(shí)的幾種傳參規(guī)范示例的文章就介紹到這了,更多相關(guān)SpringBoot MyBatis 傳參內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的方法
下面小編就為大家?guī)硪黄狫ava數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的方法。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10javaweb實(shí)戰(zhàn)之商城項(xiàng)目開發(fā)(一)
這篇文章主要針對(duì)javaweb商城項(xiàng)目開發(fā)進(jìn)行實(shí)戰(zhàn)演習(xí),對(duì)javaweb商城項(xiàng)目開發(fā)進(jìn)行詳細(xì)分析,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-02-02SpringMVC中解決@ResponseBody注解返回中文亂碼問題
這篇文章主要介紹了SpringMVC中解決@ResponseBody注解返回中文亂碼問題, 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-04-04Spring Cloud Feign報(bào)錯(cuò)問題解決
這篇文章主要介紹了Spring Cloud Feign報(bào)錯(cuò)問題解決,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12mybatis 運(yùn)行時(shí)加載自定義mapper文件方式
這篇文章主要介紹了mybatis 運(yùn)行時(shí)加載自定義mapper文件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07springmvc?html資源請(qǐng)求404的問題解決并分析
這篇文章主要介紹了springmvc?html資源請(qǐng)求404的問題解決并分析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09Java 實(shí)現(xiàn)網(wǎng)絡(luò)爬蟲框架詳細(xì)代碼
這篇文章主要介紹了Java 實(shí)現(xiàn)網(wǎng)絡(luò)爬蟲框架,主要是用于爬取網(wǎng)絡(luò)上一些內(nèi)容,比如超鏈接之類的,需要的朋友可以參考下面文章內(nèi)容2021-09-09