Mybatis中@Param的用法和作用詳解
用注解來簡化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的用法和作用,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
設(shè)計模式系列之組合模式及其在JDK和MyBatis源碼中的運用詳解
這篇文章主要介紹了組合模式及其在JDK和MyBatis源碼中的運用,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-09-09
SpringBoot實現(xiàn)動態(tài)端口切換黑魔法
這篇文章主要為大家詳細介紹了SpringBoot如何實現(xiàn)動態(tài)端口切換黑魔法,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-12-12
springboot多文件上傳實現(xiàn)使用postman測試多文件上傳接口
這篇文章主要介紹了springboot多文件上傳實現(xiàn)使用postman測試多文件上傳接口,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-08-08
Java 的雙重分發(fā)與 Visitor 模式實例詳解
這篇文章主要介紹了Java 的雙重分發(fā)與 Visitor 模式實例詳解,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2018-07-07
GC調(diào)優(yōu)實戰(zhàn)之高分配速率High?Allocation?Rate
這篇文章主要為大家介紹了GC調(diào)優(yōu)之高分配速率High?Allocation?Rate的實戰(zhàn)示例分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步2022-01-01

