单个参数: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能用
{},取出的值直接拼在sql中,有安全问题原生jdbc不支持占位符的地方zhi能用{}取值,比如分表、排序等
#{}更丰富的用法
规定参数的一下规则: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}代替,以此类推。