欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Mybatis中@Param的用法和作用詳解

 更新時(shí)間:2017年09月29日 08:52:07   作者:szu_lg  
這篇文章主要介紹了Mybatis中@Param的用法和作用,在文中給大家補(bǔ)充了spring中@param和mybatis中@param使用區(qū)別,需要的朋友可以參考下

用注解來(lái)簡(jiǎn)化xml配置的時(shí)候,@Param注解的作用是給參數(shù)命名,參數(shù)命名后就能根據(jù)名字得到參數(shù)值,正確的將參數(shù)傳入sql語(yǔ)句中

我們先來(lái)看Mapper接口中的@Select方法

package Mapper; 
public interface Mapper { 
@Select("select s_id id,s_name name,class_id classid from student where s_name= #{aaaa} and class_id = #{bbbb}") 
  public Student select(@Param("aaaa") String name,@Param("bbbb")int class_id); 
@Delete...... 
@Insert...... 
}   

這里解釋一下

1.@Select(....)注解的作用就是告訴mybatis框架,執(zhí)行括號(hào)內(nèi)的sql語(yǔ)句

2.s_id id,s_name name,class_id classid  格式是 字段名+屬性名,例如s_id是數(shù)據(jù)庫(kù)中的字段名,id是類中的屬性名

    這段代碼的作用就是實(shí)現(xiàn)數(shù)據(jù)庫(kù)字段名和實(shí)體類屬性的一一映射,不然數(shù)據(jù)庫(kù)不知道如何匹配

3.where  s_name= #{aaaa} and class_id = #{bbbb} 表示sql語(yǔ)句要接受2個(gè)參數(shù),一個(gè)參數(shù)名是aaaa,一個(gè)參數(shù)名是bbbb,如果要正確的傳入?yún)?shù),那么就要給參數(shù)命名,因?yàn)椴挥脁ml配置文件,那么我們就要用別的方式來(lái)給參數(shù)命名,這個(gè)方式就是@Param注解

4.在方法參數(shù)的前面寫(xiě)上@Param("參數(shù)名"),表示給參數(shù)命名,名稱就是括號(hào)中的內(nèi)容

public Student select(@Param("aaaa") String name,@Param("bbbb")int class_id);

給入?yún)?String name 命名為aaaa,然后sql語(yǔ)句....where  s_name= #{aaaa} 中就可以根據(jù)aaaa得到參數(shù)值了

PS:下面看下spring中@param和mybatis中@param使用區(qū)別

1.spring中@param

 /**
   * 查詢指定用戶和企業(yè)關(guān)聯(lián)有沒(méi)有配置角色
   * @param businessId memberId
   * @return
   */
   int selectRoleCount(@Param("businessId") Integer businessId,@Param("memberId") Long memberId); 

2.mybatis中的param

  /**
   * 查詢指定用戶和企業(yè)關(guān)聯(lián)有沒(méi)有配置角色
   * @param businessId memberId
   * @return
   */
   int selectRoleCount(@Param("businessId") Integer businessId,@Param("memberId") Long memberId); 

從表面上看,兩種并沒(méi)有區(qū)別,但是在xml文件中使用的時(shí)候是有區(qū)別的,Spring中的@param在xml需要如下這樣引用變量

<select id="selectRoleCount" resultType="java.lang.Integer" >
select 
  count(tbm.id)
  from t_business_member_relation tbm
  where tbm.business_id = #{0,jdbcType=INTEGER}
  and tbm.member_id = #{1,jdbcType=INTEGER}
  and tbm.role_business_id is not null
</select>

是根據(jù)參數(shù)的順序來(lái)取值的,并且從0開(kāi)始。而在mybatis @param在xml中則是如下這樣引用變量的

<select id="selectRoleCount" resultType="java.lang.Integer" >
  select 
  count(tbm.id)
  from t_business_member_relation tbm
  where tbm.business_id = #{businessId,jdbcType=INTEGER}
  and tbm.member_id = #{memberId,jdbcType=INTEGER}
  and tbm.role_business_id is not null
 </select>

是通過(guò)參數(shù)名來(lái)引用的

注:如果Mapper.java文件中引用的是Spring的

org.springframework.data.repository.query.Param;

但是Mapper.xml中使用的是mybatis 的用法,那么就會(huì)如下的錯(cuò)誤

org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.binding.BindingException: Parameter 'businessId' not found. Available parameters are [1, 0, param1, param2]

截圖如下

這里寫(xiě)圖片描述 

所以在使用的時(shí)候一定要注意@param引用和使用的一致性

總結(jié)

以上所述是小編給大家介紹的Mybatis中@Param的用法和作用,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!

相關(guān)文章

  • 徹底解決java.lang.ClassNotFoundException: com.mysql.jdbc.Driver問(wèn)題

    徹底解決java.lang.ClassNotFoundException: com.mysql.jdbc.Dr

    這篇文章給大家介紹了如如何徹底解決java.lang.ClassNotFoundException: com.mysql.jdbc.Driver問(wèn)題,文中有詳細(xì)的解決思路以及解決方法,需要的朋友可以參考下
    2023-11-11
  • Springboot自動(dòng)加載配置的原理解析

    Springboot自動(dòng)加載配置的原理解析

    Springboot遵循“約定優(yōu)于配置”的原則,使用注解對(duì)一些常規(guī)的配置項(xiàng)做默認(rèn)配置,減少或不使用xml配置,讓你的項(xiàng)目快速運(yùn)行起來(lái),這篇文章主要給大家介紹了關(guān)于Springboot自動(dòng)加載配置原理的相關(guān)資料,需要的朋友可以參考下
    2021-10-10
  • Java畢業(yè)設(shè)計(jì)實(shí)戰(zhàn)之寵物醫(yī)院與商城一體的系統(tǒng)的實(shí)現(xiàn)

    Java畢業(yè)設(shè)計(jì)實(shí)戰(zhàn)之寵物醫(yī)院與商城一體的系統(tǒng)的實(shí)現(xiàn)

    這是一個(gè)使用了java+Springboot+Jsp+maven+Mysql開(kāi)發(fā)的寵物醫(yī)院與商城一體的系統(tǒng),是一個(gè)畢業(yè)設(shè)計(jì)的實(shí)戰(zhàn)練習(xí),具有寵物醫(yī)院和寵物商城該有的所有功能,感興趣的朋友快來(lái)看看吧
    2022-02-02
  • java迭代器原理及迭代map的四種方式

    java迭代器原理及迭代map的四種方式

    本文我們將了解一下java迭代器原理及其在Java中迭代Map各種不同方法。具有一定的參考價(jià)值,感興趣的可以了解一下
    2021-09-09
  • springboot整合mybatis-plus 實(shí)現(xiàn)分頁(yè)查詢功能

    springboot整合mybatis-plus 實(shí)現(xiàn)分頁(yè)查詢功能

    這篇文章主要介紹了springboot整合mybatis-plus 實(shí)現(xiàn)分頁(yè)查詢功能,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-09-09
  • 使用IDEA工具配置和運(yùn)行vue項(xiàng)目及遇到的坑

    使用IDEA工具配置和運(yùn)行vue項(xiàng)目及遇到的坑

    這篇文章主要介紹了使用IDEA工具配置和運(yùn)行vue項(xiàng)目及遇到的坑,需要的朋友可以參考下
    2018-09-09
  • 如何利用泛型封裝通用的service層

    如何利用泛型封裝通用的service層

    這篇文章主要介紹了如何利用泛型封裝通用的service層,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • spring boot2.0總結(jié)介紹

    spring boot2.0總結(jié)介紹

    今天小編就為大家分享一篇關(guān)于spring boot2.0總結(jié)介紹,小編覺(jué)得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來(lái)看看吧
    2018-12-12
  • Spring中基于Java的配置@Configuration和@Bean用法詳解

    Spring中基于Java的配置@Configuration和@Bean用法詳解

    這篇文章主要介紹了Spring中基于Java的配置@Configuration和@Bean用法詳解,Spring中為了減少xml中配置,可以聲明一個(gè)配置類(例如SpringConfig)來(lái)對(duì)bean進(jìn)行配置。,需要的朋友可以參考下
    2019-06-06
  • Java下載Excel模板文件的簡(jiǎn)單實(shí)現(xiàn)方法

    Java下載Excel模板文件的簡(jiǎn)單實(shí)現(xiàn)方法

    這篇文章主要給大家介紹了關(guān)于Java下載Excel模板文件的簡(jiǎn)單實(shí)現(xiàn)方法,日常工作中可能經(jīng)常會(huì)涉及到用java開(kāi)發(fā)報(bào)表,需求比較多的就是表格類的報(bào)表導(dǎo)出,單元格合并,圖表的展現(xiàn),需要的朋友可以參考下
    2023-07-07

最新評(píng)論