parameterType

CRUD标签都有一个属性parameterType,statement通过它指定接收的参数类型。
接收参数的方式有两种:

1、 #{}预编译
2、${}非预编译(直接的sql拼接,不能防止sql注入)

参数类型有三种:

1、 基本数据类型
2、 HashMap(使用方式和pojo类似
3、 Pojo自定义包装类型

${}和#{}的5个区别:

1、 预编译和非预编译
2、 编译成占位符,直接拼接
3、 防sql注入和不防的区别
4、 自动判断参数类型,一个需要自行判断
5、 一个参数时#{}可以使用任意名称接收参数,${}只能使用value

对于基本数据类型和String类型 因为没有set方法(#{}和${}底层是用set来取形参的值)
所以最终的解决方法是:
在Mapper接口的方法中给形参加上@Param注解

User login(@Param("userName")String userName,@Param("password")String password);
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值