mybatis传参和取参

单个参数:mybatis不会做特殊处理

取值方式:#{参数名} 这里参数名不必与方法的形参名称一致,可以用任意参数名来接受实参
例子:方法:update(Integer id) sql映射文件取值#{a},这样也可以取到值

多个参数:mybatis会做特殊处理,即把多个参数封装成一个map ,key:param1…paramN,value:传入的参数值,#{}就是就是从map中获取指定的key的value,即#{param1},#{param2}等

多个参数处理:自定义封装参数的key

方法 get(@Param(“id”) Integer id,@Param(“name”) String name) key使用@Param注解指定的值
取值:#{id},#{name} #{自定的key}取出对应的值
如果多个参数正好是我们业务逻辑的数据模型(可以只是模型的部分数据)就可以直接传入pojo

#{属性名}取出传入的pojo属性值

如果多个参数不是我们我们业务逻辑的模型,没有对应的pojo,不推荐为了方便,我们可以传入map

#{key}取出map中对应的值

如果多个参数不是我们我们业务逻辑的模型,但是经常使用,推荐封装成一个vo(其实就是一个简单的javabean,把所有参数封装到一个java类中)

如果形参只有一个,但是形参的类型是集合(collection,list,set)或者数组,也会做特殊处理,把它们封装到map中

如果形参是collection,那么map的key是collection
如果是collection中的list,那么map的key是list,取值#{list[0]},表示取出list中第一个元素
如果是数组,那么map的key是array,取值#{array}

#{}取值和${}取值的区别

#{}是以预编译的形式,将参数设置到sql中 ,利用preparedStatement,防止sql注入
{ } , 取 出 的 值 直 接 拼 在 s q l 中 , 有 安 全 问 题 原 生 j d b c 不 支 持 占 位 符 的 地 方 z h i 能 用 {},取出的值直接拼在sql中,有安全问题 原生jdbc不支持占位符的地方zhi能用 sqljdbczhi{}取值,比如分表、排序等

#{}更丰富的用法

规定参数的一下规则:javaType、 jdbcType、 mode(存储过程)、 numericScale、
resultMap、 typeHandler、 jdbcTypeName、 expression(未来准备支持的功能)

jdbcType:数据库类型:通常需要在某种特定的条件下被设置:

在我们数据为null的时候,有些数据库可能不能识别mybatis对null的默认处理。比如Oracle(报错);

JdbcType OTHER:无效的类型;因为mybatis对所有的null都映射的是原生Jdbc的OTHER类型,oracle不能正确处理;

由于全局配置中:jdbcTypeForNull=OTHER;oracle不支持;两种办法

#{email,jdbcType=OTHER};

jdbcTypeForNull=NULL

<setting name="jdbcTypeForNull" value="NULL"/>

以上是原文,下面我补充一下

1、@Param和param1、param2可以在多参数时使用,也可以在单参数时使用。
2、使用@Param后,用param1、param2的取值方式仍然有效。
3、if、for等标签里取参,不需要使用#和{},直接参数名。
4、如果使用mybatis的if标签for标签取参,必须要用@Param里定义的参数名或param1、param2方式获取参数,用任意参数名是会报错的。
5、多参数时不能使用parameterType属性。
6、#{param1}可以用#{0}代替,#{param2}可以用#{1}代替,以此类推。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值