今天遇到mybatis批量保存报错
org.apache.ibatis.binding.BindingException: Parameter 'receptionList' not found. Available parameters are [list, collection]
就其原因是因为在xml中写SQL的时候
<insert id="batchInsert" parameterType="smsReceptionList">
INSERT INTO t_sms_reception
(
SMS_SYS,
SUBCODE,
PHONE_NUM,
SMS_CONTENT,
REQUEST_TIME,
READ_FLAG
)
VALUES
<foreach collection="list" separator ="," item="smsReception">
(
#{smsReception.smsSys},
#{smsReception.subcode},
#{smsReception.phoneNum},
#{smsReception.smsContent},
#{smsReception.readFlag}
)
</foreach>
</insert>
根据报错日志分析,是MyBatis在解析xml时找不到其中声明的studentNameList,但是在Dao中明明传的参数就是studentNameList,怎么会报错呢?
查询了一下MyBatis官方的说明文档,终于找到了原因,在http://mybatis.github.io/mybatis-3/zh/dynamic-sql.html#foreach里有一段说明:
因为我传的参数只有一个,而且传入的是一个List集合,所以mybatis会自动封装成Map<"list",studentNameList>。在解析的时候会通过“list”作为Map的key值去寻找。但是我在xml中却声明成studentNameList了,所以自然会报错找不到。