Mybatis的Mapper文件中的select、insert、update、delete元素中有一个parameterType属性,用于对应的mapper接口方法接受的参数类型。
可以接受的参数类型有基本类型和复杂类型。
mapper接口方法一般接受一个参数,可以通过使用@Param注释将多个参数绑定到一个map做为输入参数。
User selectByPrimaryKey(Integer id);
sql映射:
<
select
id
=
"selectByPrimaryKey"
resultMap
=
"BaseResultMap"
parameterType
=
"java.lang.Integer"
>
select
<
include
refid
=
"Base_Column_List"
/>
from base.tb_user
where id = #{id,jdbcType=INTEGER}
select
>
对于简单数据类型,sql映射语句中直接#{变量名}这种方式引用就行了,其实这里的"变量名"可以是任意的。mapper接口方法传递过来的值,至于其叫什么名字其实是不可考也没必要知道的。
而且JAVA反射只能获取方法参数的类型,是无从得知方法参数的名字的。
比如上面这个示例中,使用#{id}来引用只是比较直观而已,使用其他名字来引用也是一样的。所以当在if元素中test传递的参数时,就必须要用_parameter来引用这个参数了。像这样:
<
select
id
=
"selectByPrimaryKey"
resultMap
=
"BaseResultMap"
parameterType
=
"java.lang.Integer"
>
select
<
include
refid
=
"Base_Column_List"
/>
from tb_user
<
if
test
=
"_parameter != 0"
>
where id = #{id,jdbcType=INTEGER}
if
>
select
>
如果test测试条件中使用id就会提示错误,因为这个参数其实没有名字,只是一个值或引用而已,只能使用_parameter来引用。
int
insert(User user);
sql映射:
<
insert
id
=
"insert"
parameterType
=
"User"
useGeneratedKeys
=
"true"
keyProperty
=
"id"
>
insert into tb_user (name, sex)
values (#{name,jdbcType=CHAR}, #{sex,jdbcType=CHAR})
虽然可以明确的引用对象的属性名了,但如果要在if元素中测试传入的user参数,仍然要使用_parameter来引用传递进来的实际参数,因为传递进来的User对象的名字是不可考的。如果测试对象的属性,则直接引用属性名字就可以了。
测试user对象:
<
if
test
=
"_parameter != null"
>
测试user对象的属性:
<
if
test
=
"name != null"
>
int
updateByExample(
@Param
(
"user"
) User user,
@Param
(
"example"
) UserExample example);
sql映射:
<
update
id
=
"updateByExample"
parameterType
=
"map"
>
update tb_user
set id = #{user.id,jdbcType=INTEGER},
...
<
if
test
=
"_parameter != null"
>
<
include
refid
=
"Update_By_Example_Where_Clause"
/>
if
>
注意这里测试传递进来的map是否为空,仍然使用_parameter
User selectUserInList(List idlist);
sql动态语句映射:
<
select
id
=
"selectUserInList"
resultType
=
"User"
>
SELECT *
FROM USER
WHERE ID in
<
foreach
item
=
"item"
index
=
"index"
collection
=
"list"
open
=
"("
separator
=
","
close
=
")"
>
#{item}
foreach
>
select
>
List selectByExample(UserExample example);
sql映射文件:
<
where
>
<
foreach
collection
=
"oredCriteria"
item
=
"criteria"
separator
=
"or"
>
<
if
test
=
"criteria.valid"
>
在这里,UserExample有一个属性叫oredCriteria,其类型为List,所以在foreach元素里直接用属性名oredCriteria引用这个List即可。
item="criteria"表示使用criteria这个名字引用每一个集合中的每一个List或Array元素