zoukankan      html  css  js  c++  java
  • spring中@Param和mybatis中@Param使用区别(暂时还没接触)

    1、spring中@Param(org.springframework.data.repository.query.Param)   
     int selectRoleCount(@Param("businessId") Integer businessId,@Param("memberId") Long memberId); 
    2、mybatis中param(org.apache.ibatis.annotations.Param
    int selectRoleCount(@Param("businessId") Integer businessId,@Param("memberId") Long memberId); 
    从表面上看,两种并没有区别,但是在xml文件中使用的时候是有区别的,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>  
    是根据参数的顺序来取值的,并且从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>
    
    

    是通过参数名来引用的 注:如果Mapper.java文件中引用的是Spring的

     注:如果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]
     


  • 相关阅读:
    GNU make manual 翻译(九十九)
    GNU make manual 翻译( 九十五)
    Shell的 for 循环小例子
    makefile中对目录遍历的小例子
    GNU make manual 翻译(九十三)
    GNU make manual 翻译( 一百)
    GNU make manual 翻译( 九十七)
    GNU make manual 翻译( 九十八)
    mapserver4.8.3 的readme.win32的中文翻译文件
    遥控器编程
  • 原文地址:https://www.cnblogs.com/zouhong/p/11808736.html
Copyright © 2011-2022 走看看