Mybatis中@Param的用法和作用詳解
用注解來(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]
截圖如下
所以在使用的時(shí)候一定要注意@param引用和使用的一致性
總結(jié)
以上所述是小編給大家介紹的Mybatis中@Param的用法和作用,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
相關(guān)文章
徹底解決java.lang.ClassNotFoundException: com.mysql.jdbc.Dr
這篇文章給大家介紹了如如何徹底解決java.lang.ClassNotFoundException: com.mysql.jdbc.Driver問(wèn)題,文中有詳細(xì)的解決思路以及解決方法,需要的朋友可以參考下2023-11-11Java畢業(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-02springboot整合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)目及遇到的坑,需要的朋友可以參考下2018-09-09Spring中基于Java的配置@Configuration和@Bean用法詳解
這篇文章主要介紹了Spring中基于Java的配置@Configuration和@Bean用法詳解,Spring中為了減少xml中配置,可以聲明一個(gè)配置類(例如SpringConfig)來(lái)對(duì)bean進(jìn)行配置。,需要的朋友可以參考下2019-06-06Java下載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