MyBatis插入时获取自增id

文章介绍了如何在MyBatis中使用注释和XML配置文件来处理插入数据时获取自增ID的情况。通过@Insert注解和@Options设置useGeneratedKeys为true,可以获取新插入行的ID。同样,在XML映射文件中设置useGeneratedKeys属性也可以实现相同功能。
摘要由CSDN通过智能技术生成

关于MyBatis在插入时获取自增id

1.1 注释方法

@Insert("insert into book(bid, bname, price, number, cratedate) values(null,#{bname},#{price},#{number},#{cratedate}) ")
    int add(Book book);
//注意:在mapper中是不能重载的这里我特意写为add01
    @Insert("insert into book set  bname = #{name}, price =#{price}")
    @Options(useGeneratedKeys = true,keyColumn = "bid",keyProperty = "id")
    int add01(Map<String,Object> map);

主程序也就是测试程序可以查看结果

@Test
void add(){
    Map<String,Object> map = new HashMap<>();
    map.put("name","《钢铁是怎样连城的》");
    map.put("price",60.6);
    map.put("cratedate",LocalDateTime.now());
    System.out.println(map);
    bm.add01(map);
    System.out.println(map);

}

结果

在这里插入图片描述

1.2 xml配置文件中书写

mapper

int add02(Map<String,Object> map);

对应的xml

   <insert id="add02" useGeneratedKeys="true" keyColumn="bid" keyProperty="id">
        insert into book set  bname = #{name}, price =#{price};
    </insert>
 
   @Test
    void add2xml(){
        Map<String,Object> map = new HashMap<>();
        map.put("name","《活着》");
        map.put("price",60.6);
        map.put("cratedate",LocalDateTime.now());
        System.out.println(map);
        bm.add02(map);
        System.out.println(map);

    }

结果

在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值