mybatis中传入多个参数的4个解决方法

mybatis中传入多个参数的4个解决方法

问题引入

想必大家可能遇到过类似的错误,当传入多个参数时,映射文件无法获得传入的参数
这里写图片描述
我的例子

// 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); 

so,我觉得应该把题目改为,mybatis中传入多个参数的2个解决方法。毕竟3、4是通过把多个参数转化为1个参数的方式解决问题的,哈哈。


5 拓展(接口中传入参数的各种情况)

5.1 当只有一个参数时

使用arg0,param1获得参数是一直有效的,但是个人不推荐这样做,毕竟看起来不优雅

5.1.1 参数是基本类型

xml中标签内的变量名可以随便写,#{id},#{ids},#{123},#{xxgdsgdg},等都可以获得到参数。

5.1.2 参数是javabean

xml中标签内直接填写Javabean中的属性名

5.1.3 参数是数组

使用array获得参数,再用foreach循环

5.1.4 参数是List

使用list或collection获得参数,再用foreach循环

5.1.5 参数是Set

使用collection获得参数,再用foreach循环

5.2 当有多个参数时

使用argN、paramN或@param定位到某个参数,再灵活使用ognl就ok了。比如#{user.name}、#{users[0].name}。
  • 24
    点赞
  • 110
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
MyBatis是一个优秀的Java持久化框架,它可以轻松地将数据库表和Java对象之间进行映射。在开发过程,我们通常需要向MyBatis的SQL语句多个参数。下面我们来介绍MyBatis多个参数方法。 1. 使用Map参数。 通过使用Map来多个参数,可以将多个参数打包到一个Map对象。在MyBatis的Mapper.xml文件,使用#{key}来引用Map参数值。例如,如果我们要递两个参数,一个是username,一个是age,可以使用如下的方式: ``` <select id="getUser" parameterType="map" resultType="User"> SELECT * FROM user WHERE username = #{username} AND age = #{age} </select> ``` 在Java使用Map参数的例子如下: ``` Map<String, Object> parameterMap = new HashMap<>(); parameterMap.put("username", "张三"); parameterMap.put("age", 18); User user = sqlSession.selectOne("getUser", parameterMap); ``` 2. 使用@Param注解参数。 @Param注解可以用来指定参数的名称,从而在Mapper.xml文件和Java使用相同的参数。在Mapper.xml文件,使用#{参数名}来引用参数值。例如,如果我们要递两个参数,一个是username,一个是age,可以使用如下的方式: ``` <select id="getUser" parameterType="map" resultType="User"> SELECT * FROM user WHERE username = #{username} AND age = #{age} </select> ``` 在Java使用@Param注解参数的例子如下: ``` public User getUser(@Param("username") String username, @Param("age") int age); ``` 3. 使用JavaBean参数。 在Java,我们可以使用JavaBean来封装多个参数,然后在Mapper.xml文件使用#{属性名}来引用JavaBean属性的值。例如,如果我们要递两个参数,一个是username,一个是age,可以使用如下的JavaBean: ``` public class UserInfo { private String username; private int age; // getter/setter } ``` 在Mapper.xml文件,可以如下使用JavaBean参数: ``` <select id="getUser" parameterType="UserInfo" resultType="User"> SELECT * FROM user WHERE username = #{username} AND age = #{age} </select> ``` 在Java使用JavaBean参数的例子如下: ``` UserInfo userInfo = new UserInfo(); userInfo.setUsername("张三"); userInfo.setAge(18); User user = sqlSession.selectOne("getUser", userInfo); ``` 总之,MyBatis多个参数方法有很多,主要是使用Map、@Param注解和JavaBean来封装参数。在使用的时候,我们需要根据具体情况,选择最适合的方法参数

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值