MyBatis插入与批量插入ID原理深度解析

5星 · 超过95%的资源 3 下载量 85 浏览量 更新于2024-09-01 1 收藏 81KB PDF 举报
"mybatis插入与批量插入返回ID的原理详解" 在MyBatis中,当我们执行插入操作时,有时需要获取新插入记录的自增ID。MyBatis提供了这样的功能,让我们能够在插入数据后方便地获取到生成的主键值。本文将详细解释MyBatis如何在单个插入和批量插入时返回ID的机制。 首先,了解MyBatis的基本工作流程。MyBatis是一个优秀的持久层框架,它允许开发者将SQL语句编写在XML映射文件或注解中,然后通过Java接口与数据库进行交互。当执行插入操作时,MyBatis会根据配置的SQL语句执行相应的INSERT命令。 1. 单个对象插入: 在单个对象插入时,MyBatis会查找与插入操作对应的XML映射文件中的`<insert>`标签。在这个标签中,我们可以使用`useGeneratedKeys="true"`和`keyProperty="id"`属性来告诉MyBatis返回生成的主键并将其赋值给对象的指定属性。例如: ```xml <insert id="insertUser" parameterType="com.example.User" useGeneratedKeys="true" keyProperty="id"> INSERT INTO user(name, email) VALUES (#{name}, #{email}) </insert> ``` 在上述示例中,`useGeneratedKeys="true"`开启获取自增ID的功能,而`keyProperty="id"`指定了将ID结果存入User对象的id字段。 2. 批量插入: 批量插入时,MyBatis通常会使用`<insert>`标签的`<foreach>`子标签来处理多个对象。但是,对于返回ID的情况,MyBatis默认不支持批量插入后的主键生成。如果数据库支持批量返回自增ID(如MySQL的LAST_INSERT_ID()),可以通过自定义SQL语句实现。例如: ```xml <insert id="batchInsertUser" parameterType="java.util.List"> INSERT INTO user(name, email) <foreach item="item" index="index" collection="list" separator=","> (#{item.name}, #{item.email}) </foreach> <!-- MySQL 特有的方式,获取批量插入后的最后一个自增ID --> <selectKey resultType="long" keyProperty="id" order="AFTER"> SELECT LAST_INSERT_ID() </selectKey> </insert> ``` 在这个例子中,`<selectKey>`标签用于获取插入操作后的主键,`order="AFTER"`表示在INSERT语句执行后执行。然而,这种方法只适用于某些数据库,如MySQL。对于不支持批量返回自增ID的数据库,你可能需要在插入后执行额外的查询来获取每个新记录的ID。 3. MyBatis的Executor执行器: MyBatis的Executor执行器负责执行SQL语句。在自动获取主键的情况下,SimpleExecutor会在插入后调用`Statement.getGeneratedKeys()`方法来获取生成的ID。而BatchExecutor则不支持直接获取批量插入的主键,因为它执行的是批量SQL语句,而不是单独的插入操作。 4. Spring集成: 在Spring中,如果使用了`@Autowired`的`SqlSessionTemplate`或`SqlSessionDaoSupport`,可以调用`insert()`方法执行插入操作。这个方法会返回一个int值,表示受影响的行数。如果开启了`useGeneratedKeys`,那么对于单条插入,返回的主键值可以通过`selectKey`标签获取;而对于批量插入,通常需要自己实现逻辑来获取每个对象的主键。 总结,MyBatis在插入操作时返回ID主要依赖于SQL语句的配置,以及数据库是否支持批量返回自增ID。对于单个插入,通过`useGeneratedKeys`和`keyProperty`可以轻松获取新ID;而在批量插入时,情况会复杂一些,可能需要特定数据库的特性或者自定义逻辑来实现。在Spring环境中,可以通过`SqlSession`或`SqlSessionTemplate`的相关方法来执行插入操作并获取结果。
2025-02-15 上传
# 医护人员排班系统 ## 1. 项目介绍 本系统是一个基于SpringBoot框架开发的医护人员排班管理系统,用于医院管理医护人员的排班、调班等工作。系统提供了完整的排班管理功能,包括科室管理、人员管理、排班规则配置、自动排班等功能。 ## 2. 系统功能模块 ### 2.1 基础信息管理 - 科室信息管理:维护医院各科室基本信息 - 医护人员管理:管理医生、护士等医护人员信息 - 排班类型管理:配置不同的排班类型(如:早班、中班、晚班等) ### 2.2 排班管理 - 排班规则配置:设置各科室排班规则 - 自动排班:根据规则自动生成排班计划 - 排班调整:手动调整排班计划 - 排班查询:查看各科室排班情况 ### 2.3 系统管理 - 用户管理:管理系统用户 - 角色权限:配置不同角色的操作权限 - 系统设置:管理系统基础配置 ## 3. 技术架构 ### 3.1 开发环境 - JDK 1.8 - Maven 3.6 - MySQL 5.7 - SpringBoot 2.2.2 ### 3.2 技术栈 - 后端框架:SpringBoot - 持久层:MyBatis-Plus - 数据库:MySQL - 前端框架:Vue.js - 权限管理:Spring Security ## 4. 数据库设计 主要数据表: - 科室信息表(keshixinxi) - 医护人员表(yihurengyuan) - 排班类型表(paibanleixing) - 排班信息表(paibanxinxi) - 用户表(user) ## 5. 部署说明 ### 5.1 环境要求 - JDK 1.8+ - MySQL 5.7+ - Maven 3.6+ ### 5.2 部署步骤 1. 创建数据库并导入SQL脚本 2. 修改application.yml中的数据库配置 3. 执行maven打包命令:mvn clean package 4. 运行jar包:java -jar xxx.jar ## 6. 使用说明 ### 6.1 系统登录 - 管理员账号:admin - 初始密码:admin ### 6.2 基本操作流程 1. 维护基础信息(科室、人员等) 2. 配置排班规则 3. 生成排班计划 4. 查看和调整排班 ## 7. 注意事项 1. 首次使用请及时修改管理员密码 2. 定期备份数据库 3. 建议定期检查和优化排班规则