news 2026/6/5 17:25:31

mybatis-plus 基于 Mapper接口的 insert

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
mybatis-plus 基于 Mapper接口的 insert

基于BaseMapper的crud

  • 通用 CRUD 封装BaseMapper接口,
  • Mybatis-Plus 启动时,自动解析实体表关系映射转换为 Mybatis 内部对象注入容器,内部包含常见的单表操作

insert

"插入一条记录"T就是要插入的实体对象 默认主键生成策略为雪花算法(后面讲解)intinsert(Tentity);
类型参数名描述
Tentity实体对象



insert 举例详解

前置准备

已定义的User实体类(稍补充主键策略说明):

importcom.baomidou.mybatisplus.annotation.IdType;importcom.baomidou.mybatisplus.annotation.TableId;importcom.baomidou.mybatisplus.annotation.TableName;importlombok.Data;@Data@TableName("user")// 对应数据库user表publicclassUser{// 主键策略:// 1. IdType.AUTO:数据库自增(需先给数据库表id字段设置自增)// 2. IdType.ASSIGN_ID(默认):雪花算法生成Long型ID// 3. IdType.INPUT:手动输入主键值@TableId(type=IdType.AUTO)privateLongid;// 用户IDprivateStringusername;// 用户名privateIntegerage;// 年龄privateStringemail;// 邮箱}

UserMapper接口(继承BaseMapper<User>即可使用insert方法):

importcom.baomidou.mybatisplus.core.mapper.BaseMapper;importorg.apache.ibatis.annotations.Mapper;@MapperpublicinterfaceUserMapperextendsBaseMapper<User>{// 无需手动编写insert方法,BaseMapper已内置}

insert(T entity) 方法使用示例

示例1:基础使用(数据库自增主键)

适用于主键为数据库自增的场景(对应@TableId(type = IdType.AUTO)):

importorg.springframework.stereotype.Service;importjavax.annotation.Resource;@ServicepublicclassUserService{@ResourceprivateUserMapperuserMapper;/** * 插入一条用户记录(数据库自增主键) */publicvoidinsertUser(){// 1. 创建实体对象,无需设置id(自增策略下会由数据库自动生成)Useruser=newUser();user.setUsername("zhangsan");// 设置用户名user.setAge(25);// 设置年龄user.setEmail("zhangsan@example.com");// 设置邮箱// 2. 调用insert方法,返回值为「受影响的行数」(插入成功返回1,失败返回0)intaffectedRows=userMapper.insert(user);// 3. 关键:插入后,实体对象的id会被**自动回填**System.out.println("插入受影响行数:"+affectedRows);// 输出:1System.out.println("插入后生成的主键ID:"+user.getId());// 输出:数据库自增的ID(如1、2、3...)}}
示例2:默认雪花算法主键(IdType.ASSIGN_ID)

如果将User实体的主键策略改为默认的雪花算法:

// 修改User类的主键注解@TableId(type=IdType.ASSIGN_ID)privateLongid;

调用逻辑不变,但主键生成规则不同:

publicvoidinsertUserWithSnowflakeId(){Useruser=newUser();user.setUsername("lisi");user.setAge(30);user.setEmail("lisi@example.com");intaffectedRows=userMapper.insert(user);System.out.println("插入受影响行数:"+affectedRows);// 输出:1// 雪花算法生成的Long型ID(如175689876543219876)System.out.println("雪花算法生成的主键ID:"+user.getId());}
示例3:手动输入主键(IdType.INPUT)

适用于需要自定义主键值的场景:

// 修改User类的主键注解@TableId(type=IdType.INPUT)privateLongid;

调用时需手动设置id:

publicvoidinsertUserWithCustomId(){Useruser=newUser();user.setId(100L);// 手动指定主键IDuser.setUsername("wangwu");user.setAge(28);user.setEmail("wangwu@example.com");intaffectedRows=userMapper.insert(user);System.out.println("插入受影响行数:"+affectedRows);// 输出:1System.out.println("手动设置的主键ID:"+user.getId());// 输出:100}

关键注意事项

  1. 插入时,如果实体字段值为null
    MyBatis-Plus 会忽略该字段,
    数据库中对应列,会按默认值填充(如null或数据库设置的默认值);
  2. 雪花算法生成的ID是全局唯一的,适合分布式系统,无需依赖数据库自增;
  3. 若,数据库表字段 和 实体属性名 不一致,需用@TableField(value = "数据库列名")映射。

总结

  1. insert(T entity)方法返回受影响的行数,插入成功返回1,失败返回0;
  2. 主键生成策略由实体类@TableIdtype决定,
    默认是雪花算法(IdType.ASSIGN_ID)
  3. 插入完成后,实体对象的id字段会被自动回填,可直接获取生成的主键值。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/3 0:19:00

计算机毕业设计之springboot基于Java的远程就医系统

随着网络科技的不断发展以及人们经济水平的逐步提高&#xff0c;网络技术如今已成为人们生活中不可缺少的一部分&#xff0c;而信息管理系统是通过计算机技术&#xff0c;针对用户需求开发与设计&#xff0c;该技术尤其在各行业领域发挥了巨大的作用&#xff0c;有效地促进了远…

作者头像 李华
网站建设 2026/6/1 7:07:50

汽车研发系统如何通过wangEditor实现MATLAB公式Web导入?

今天早上刚打开电脑&#xff0c;就收到一位教育行业开发者的微信咨询——对方正在为某初中学校开发智慧校园平台&#xff0c;急需在wangEditor编辑器中实现Word文档一键导入功能&#xff0c;重点需要解决教学场景中图片和公式的自动上传问题。虽然我的技术博客里公开了联系方式…

作者头像 李华
网站建设 2026/5/25 15:29:33

DB13/T6152-2025 深度解析:河北省自来水行业节能降耗的标准化路径

在双碳目标引领下&#xff0c;高耗能行业的节能转型已成为行业可持续发展的核心议题。自来水生产作为城市运行的基础保障领域&#xff0c;其能源消耗水平直接关系到行业绿色发展质量。河北省地方标准 DB13/T6152-2025《自来水单位产品能源消耗限额引导性指标》的发布与实施&…

作者头像 李华
网站建设 2026/6/4 20:29:36

【开题答辩全过程】以 海南农产品销售系统为例,包含答辩的问题和答案

个人简介一名14年经验的资深毕设内行人&#xff0c;语言擅长Java、php、微信小程序、Python、Golang、安卓Android等开发项目包括大数据、深度学习、网站、小程序、安卓、算法。平常会做一些项目定制化开发、代码讲解、答辩教学、文档编写、也懂一些降重方面的技巧。感谢大家的…

作者头像 李华