问题:
想必大家可能遇到过类似的错误,当传入多个参数时,映射文件无法获得传入的参数
// javabean
public class User {
private int id;
private String name;
private byte age;
// 忽略了getter、setter方法
}
// 接口
public interface UserMapper {
List<User> select(String name,byte age);
}
// 映射文件
<select id="select" resultType="model.User">
select * from `user` where name = #{id} and age =#{age}
</select>
1. 利用参数出现的顺序
Parameter ‘id’ not found. Available parameters are [arg1, arg0, param1, param2],这句话的意思就是id找不到,可用的参数是[arg1, arg0, param1, param2]。所以可使用参数出现的顺序号码引用参数,第一个参数用arg0或param1表示,第二个参数用arg1或param2表示,以此类推(arg从0开始计数,param从1开始计数)。
修改xml为如下方式:
<select id="select" resultType="model.User">
select * from `user` where name = #{arg0} and age =#{arg1}
</select>
// or
<select id="select" resultType="model.User">
select * from `user` where name = #{param1} and age =#{param2}
</select>
2.使用注解
给接口中方法的参数加上注解,xml不变
public interface UserMapper {
List<User> select(@Param("name") String name,@Param("age") byte age);
}
3.使用map
3.1把接口的形参改为Map
// 接口
public interface UserMapper {
List<User> select(Map params);
}
3.2 把需要的参数封装在map中
Map params = new HashMap();
params.put("name", "王尼玛");
params.put("age", 32);
List<User> list = userMapper.select(params);
4.把参数封装在Javabean中
4.1 把接口的形参改为javabean
// 接口
public interface UserMapper {
List<User> select(User user);
}
4.2 把需要的参数封装在javabean中
User user = new User();
user.setName("四");
user.setAge((byte)43);
List<User> list = userMapper.select(user);
5 使用list
public List<XXXBean> getXXXBeanList(List<String> list);
<select id="getXXXBeanList" resultType="XXBean">
select 字段... from XXX where id in
<foreach item="item" index="index" collection="list" open="(" separator="," close=")">
#{item}
</foreach>
</select>
foreach 最后的效果是select 字段... from XXX where id in ('1','2','3','4')