亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

SpringBoot使用MyBatis時的幾種傳參規(guī)范示例

 更新時間:2022年02月20日 10:29:23   作者:工作事小摸魚事大  
使用Mybatis作為持久層框架時,對于數(shù)據(jù)庫的增刪改查等操作都需要參數(shù)的傳遞,本文就詳細(xì)的介紹了一下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ù)組元素的方法

    Java數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的方法

    下面小編就為大家?guī)硪黄狫ava數(shù)組,去掉重復(fù)值、增加、刪除數(shù)組元素的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-10-10
  • javaweb實戰(zhàn)之商城項目開發(fā)(一)

    javaweb實戰(zhàn)之商城項目開發(fā)(一)

    這篇文章主要針對javaweb商城項目開發(fā)進(jìn)行實戰(zhàn)演習(xí),對javaweb商城項目開發(fā)進(jìn)行詳細(xì)分析,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-02-02
  • SpringMVC中解決@ResponseBody注解返回中文亂碼問題

    SpringMVC中解決@ResponseBody注解返回中文亂碼問題

    這篇文章主要介紹了SpringMVC中解決@ResponseBody注解返回中文亂碼問題, 小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-04-04
  • Spring Cloud Feign報錯問題解決

    Spring Cloud Feign報錯問題解決

    這篇文章主要介紹了Spring Cloud Feign報錯問題解決,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12
  • Java中的事件處理機(jī)制詳解

    Java中的事件處理機(jī)制詳解

    這篇文章主要介紹了Java中的事件處理機(jī)制詳解,Java事件處理是采取"委派事件模型",當(dāng)事件發(fā)生時,產(chǎn)生事件的對象,會把此"信息"傳遞給"事件的監(jiān)聽者"處理,這里所說的"信息"實際上就是java.awt.event事件類庫里某個類創(chuàng)建對象,把它稱為"事件的對象",需要的朋友可以參考下
    2023-10-10
  • mybatis 運(yùn)行時加載自定義mapper文件方式

    mybatis 運(yùn)行時加載自定義mapper文件方式

    這篇文章主要介紹了mybatis 運(yùn)行時加載自定義mapper文件方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-07-07
  • SpringCloud重試機(jī)制配置詳解

    SpringCloud重試機(jī)制配置詳解

    本篇文章主要介紹了SpringCloud重試機(jī)制配置詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-04-04
  • springmvc?html資源請求404的問題解決并分析

    springmvc?html資源請求404的問題解決并分析

    這篇文章主要介紹了springmvc?html資源請求404的問題解決并分析,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-09-09
  • Java 實現(xiàn)網(wǎng)絡(luò)爬蟲框架詳細(xì)代碼

    Java 實現(xiàn)網(wǎng)絡(luò)爬蟲框架詳細(xì)代碼

    這篇文章主要介紹了Java 實現(xiàn)網(wǎng)絡(luò)爬蟲框架,主要是用于爬取網(wǎng)絡(luò)上一些內(nèi)容,比如超鏈接之類的,需要的朋友可以參考下面文章內(nèi)容
    2021-09-09
  • JAVA集合框架Map特性及實例解析

    JAVA集合框架Map特性及實例解析

    這篇文章主要介紹了JAVA集合框架Map特性及實例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04

最新評論