Mybatis中的万能Map

场景:当我们的实体类,或者数据库中的表,字段或者参数过多,我们可以考虑使用万能Map!!!

  1. Map 传递参数,直接在 sql 中取出key即可!【parameterType=“map”】
  2. 对象传递参数,直接在 sql 中取对象的属性即可!【parameterType=“Object”】
  3. 只有一个基本类型参数的情况下,可以直接在 sql 中取到!
  4. 多个参数用Map,或者注解!

  • 实体类
public class User {

    private Integer id;

    private String name;

    private String pwd;

    public User() {
    }

    public User(Integer id, String name, String pwd) {
        this.id = id;
        this.name = name;
        this.pwd = pwd;
    }

    public Integer getId() {
        return id;
    }

    public void setId(Integer id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public String getPwd() {
        return pwd;
    }

    public void setPwd(String pwd) {
        this.pwd = pwd;
    }

    @Override
    public String toString() {
        return "User{" +
                "id=" + id +
                ", name='" + name + '\'' +
                ", pwd='" + pwd + '\'' +
                '}';
    }
}
  • 接口
//万能Map,参数是一个Map
int addUser(Map<String, Object> map);
  • mybatis 映射文件中
<!--添加一个用户,对象中的属性可以直接取出来,传递map的key-->
<insert id="addUser" parameterType="map">
    insert into `user` (id,pwd) values (#{userId},#{passWord})
</insert>
  • 测试类
@Test
public void test(){

     SqlSession sqlSession = MybatisUtils.getSqlSession();

     UserMapper mapper = sqlSession.getMapper(UserMapper.class);

     HashMap<String, Object> map = new HashMap<>();

     map.put("userId",5);
     map.put("passWord","456123");

     mapper.addUser(map);
        
     sqlSession.commit();
        
     sqlSession.close();
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值