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

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

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

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

我們先來看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í)行括號內(nèi)的sql語句

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

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

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

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

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

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

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

1.spring中@param

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

2.mybatis中的param

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

從表面上看,兩種并沒有區(qū)別,但是在xml文件中使用的時候是有區(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ù)的順序來取值的,并且從0開始。而在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>

是通過參數(shù)名來引用的

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

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

但是Mapper.xml中使用的是mybatis 的用法,那么就會如下的錯誤

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

截圖如下

這里寫圖片描述 

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

總結(jié)

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

相關(guān)文章

  • 徹底解決java.lang.ClassNotFoundException: com.mysql.jdbc.Driver問題

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

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

    Springboot自動加載配置的原理解析

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

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

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

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

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

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

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

    使用IDEA工具配置和運行vue項目及遇到的坑

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

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

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

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

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

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

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

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

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

最新評論