在Mybatis中编写Mapper.xml时传入查询参数占位符的总结

Mybatis在编写Sql时候传递参数的方式:

1.使用对象属性,其中id、membershipName ..都为User对象的属性名;

mapper接口中的代码:

int insertUser(User user);

mapper.xml中的代码:

<insert id="insertUser">
    insert into user(user_id, membership_name, tel, password, registration_time)
    values(#{id}, #{membershipName}, #{tel}, #{password}, #{registrationTime, jdbcType=TIMESTAMP})
</insert>

2.使用参数

mapper接口中的代码:

User getUser(String membershipName, String password);

mapper.xml中的代码:

<select id="getUser" resultType="User">
    select user_id id,membership_name membershipName
    from user
    where membership_name = #{arg0} and password = #{arg1}  
</select>

可以使用#{arg0}, #{arg1},或者#{param1}, #{param2} ...#{paramN}来进行占位。

当使用#{0},#{1}的方式不在可以用,将会出现以下错误,大概的意思是参数 0 不可用,可用的为 [arg1, arg0, param1, param2]

org.mybatis.spring.MyBatisSystemException: nested exception is 

org.apache.ibatis.binding.BindingException: Parameter '0' not found. Available parameters 
 
are [arg1, arg0, param1, param2]

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值