SpringBoot使用MyBatis時的幾種傳參規(guī)范示例
使用Mybatis作為持久層框架時,對于數(shù)據(jù)庫的增刪改查等操作都需要參數(shù)的傳遞,這里學(xué)習(xí)記錄一下MyBatis中可用的參數(shù)傳遞方式。
1. 單個簡單參數(shù)傳遞
使用 MyBatis 傳遞單個參數(shù)時比較簡單,形式如#{a}
,#
,#{param1}
等都可以在 MyBatis 中獲取到唯一參數(shù),但是參數(shù)名盡量和入?yún)⒚恢?,這樣更符合開發(fā)規(guī)范。
Mapper 文件定義
UserInfo selectById(String userId);
xml 文件定義
- 單個參數(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ù)傳遞時使用的是 MyBatis 中索引傳遞的方式,對于傳遞的多個參數(shù),在sql
語句標(biāo)簽中使用#{param1}
、#{param2}
等索引依次代表傳入的參數(shù)值。
Mapper 文件
- 使用匿名參數(shù)傳遞時,接口中定義的方法參數(shù)無需使用注解
UserInfo selectByNameAndAge(String userName, Integer age);
xml 文件
- xml中讀取參數(shù)時可以使用使用arg0, arg1, param1, param2等形式
- 參數(shù)有多個類型且匿名,因此不需要指定入?yún)㈩愋?/li>
- Mapper中沒有使用注解,因此直接使用參數(shù)名時會報錯參數(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ù)傳遞方法可讀性差,對后期維護(hù)不友好,不符合開發(fā)規(guī)范。
3. 使用@Param注解傳遞
@Param注解用于指定key,指定了key之后,在sql
標(biāo)簽中可以使用key來索引對應(yīng)的參數(shù)值。
Mapper 文件
- 接口中定義時使用 @Param注解指定參數(shù)對應(yīng)的key
UserInfo selectByNameAndAge(@Param("userName") String userName, @Param("age") Integer age);
xml 文件
- 不需要指定傳入?yún)?shù)類型
- 使用注解指定的key就可以獲取到對應(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注解傳參使用時清晰簡潔明了,符合開發(fā)規(guī)范,在參數(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ù)放入到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è)計,性能也沒有問題,但是在開發(fā)中由于將所有值封裝成為map,無法直觀看到map中可能含有的參數(shù),在后期維護(hù)上不太友好。
5. 使用JavaBean(POJO)傳遞
除了Map方式,還可以使用JavaBean的方式來傳遞多個參數(shù),此時在sql
標(biāo)簽中直接使用bean對象的屬性來索引參數(shù)值,注意bean對象中 需要有相應(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ù)傳遞方式更符合項目開發(fā)的規(guī)范,實際使用時簡潔明了,在參數(shù)較多時建議使用這種方式,創(chuàng)建JavaBean來作為參數(shù)傳遞對象。
6. 使用List、Array、Set傳遞
List、Array、Set等方式的傳參通常用于sql
標(biāo)簽中的in操作,即用于MyBatis中的標(biāo)簽。
使用list或array時,一般是做in操作,只有一個參數(shù)。
Mapper 文件
UserInfo selectByIdList(List<String> userIdList);
xml 文件
- 不需要指定入?yún)㈩愋?,或指定為List
- 使用標(biāo)簽處理sql中的in操作
- 如果參數(shù)是list,則collection為list;如果參數(shù)類型是array,則collection是array
- 如果是多個參數(shù)或者是對象的屬性值作為list,則傳參應(yīng)為map/bean類型,collection應(yīng)為對象屬性中的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時的幾種傳參規(guī)范示例的文章就介紹到這了,更多相關(guān)SpringBoot MyBatis 傳參內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Java數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的方法
下面小編就為大家?guī)硪黄狫ava數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10SpringMVC中解決@ResponseBody注解返回中文亂碼問題
這篇文章主要介紹了SpringMVC中解決@ResponseBody注解返回中文亂碼問題, 小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-04-04mybatis 運(yùn)行時加載自定義mapper文件方式
這篇文章主要介紹了mybatis 運(yùn)行時加載自定義mapper文件方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07Java 實現(xiàn)網(wǎng)絡(luò)爬蟲框架詳細(xì)代碼
這篇文章主要介紹了Java 實現(xiàn)網(wǎng)絡(luò)爬蟲框架,主要是用于爬取網(wǎng)絡(luò)上一些內(nèi)容,比如超鏈接之類的,需要的朋友可以參考下面文章內(nèi)容2021-09-09