MyBatis向sql语句中传参数的问题

这里只讨论向sql语句中传的参数为原始类型时,例如String ,int 等,而不是map,对象等

传多个参数时

需要在dao层使用@Param 注解来标识每个参数,如下

int deleteAbilityDetail(@Param(value = "userId")String userId, @Param(value = "abilityId") String abilityId);

括号中的value值为向sql语句中传入时的名字,这里在sql语句中有两种写法
1. 指定参数名字

<delete id="deleteAbilityDetail">
        delete from t_ability
        where user_id=#{userId} and id=#{abilityId}
    </delete>
  1. 根据参数索引
<delete id="deleteAbilityDetail">
        delete from t_ability
        where user_id=#{0} and id=#{1}
    </delete>
传递单个参数时
  • 当sql语句中,没有对传入的参数进行if判断时,dao层可以不使用@Param注解,直接在sql语句中使用参数名字或参数索引即可
  • 当sql语句中,对传入的参数进行了if判断,dao层需使用@Param注解,在sql语句中使用参数名字或参数索引即可
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值