Mybatis自动生成id,以及insert语句什么时候需要写id字段?什么时候不需要写id字段?

本文详细介绍了如何在MyBatis中使用useGeneratedKeys属性自动生成ID,适用于设置了自增ID的数据库如MySQL,同时也提供了未设置自增情况下生成ID的方法。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

mybatis可以使用useGeneratedKeys来自动生成id(其他数字的值也一样可以):

    	<insert id="save" parameterType="UserAlias" useGeneratedKeys="true" keyProperty="id">
	        INSERT INTO userinfo(username,age)
	        VALUES
	        (#{username}, #{age})
        </insert>

上面的代码是针对mysql,在数据库中设置了id自增长的示例。

keyProperty这里指定自动增长的字段,我这里是id。所以下边的insert中可以不写id字段,前提是数据库中一定要设置好id的自增长。

如果数据库中没有设置自增长可以用下面代码:

<insert id="save" parameterType="UserAlias" useGeneratedKeys="true" keyProperty="id">
	<selectKey keyProperty="id" resultType="long" order="BEFORE">
    	SELECT if(max(id) is null,1,MAX(id) + 1 ) as id from userinfo
    </selectKey>
    INSERT INTO userinfo(id,username,age)
    VALUES (#{id}, #{username}, #{age})
</insert>

这时候的insert语句就要写上id字段喽。
这儿,我们就简单提一下 这个元素节点吧:

<selectKey
        <!-- selectKey 语句结果应该被设置的目标属性。如果希望得到多个生成的列,也可以是逗号分隔的属性名称列表。 -->
        keyProperty="id"
        <!-- 结果的类型。MyBatis 通常可以推算出来,但是为了更加确定写上也不会有什么问题。MyBatis 允许任何简单类型用作主键的类型,包括字符串。如果希望作用于多个生成的列,则可以使用一个包含期望属性的 Object 或一个 Map。 -->
        resultType="int"
        <!-- 这可以被设置为 BEFORE 或 AFTER。如果设置为 BEFORE,那么它会首先选择主键,设置 keyProperty 然后执行插入语句。如果设置为 AFTER,那么先执行插入语句,然后是 selectKey 元素 - 这和像 Oracle 的数据库相似,在插入语句内部可能有嵌入索引调用。 -->
        order="BEFORE"
        <!-- 与前面相同,MyBatis 支持 STATEMENT,PREPARED 和 CALLABLE 语句的映射类型,分别代表 PreparedStatement 和 CallableStatement 类型。 -->
        statementType="PREPARED">
### MyBatis Insert 返回主键 ID 示例 对于希望在执行插入操作后获取生成的主键ID的情况,MyBatis 提供了简洁而有效的解决方案。当使用MySQL作为数据库时,在Mapper XML文件中定义`<insert>`语句时应指定两个重要属性:`useGeneratedKeys="true"`以及`keyProperty`指向实体类中的相应字段名称[^2]。 下面是一个具体的实例展示如何配置: ```xml <!-- RoleMapper.xml --> <mapper namespace="com.example.mapper.RoleMapper"> <!-- 插入角色信息并返回新创建的角色ID --> <insert id="addRole" parameterType="com.example.model.Role" useGeneratedKeys="true" keyProperty="roleId"> INSERT INTO roles (role_name, description) VALUES (#{name}, #{description}) </insert> </mapper> ``` 这段代码片段展示了向名为`roles`的数据表内添加一条记录的同时利用`useGeneratedKeys=true`指示MyBatis启用JDBC驱动程序提供的自动生成键功能;并通过设定`keyProperty="roleId"`告知框架将产生的主键赋给传入对象里的`roleId`成员变量。 为了验证此过程是否成功完成,可以在Java服务层编如下测试案例: ```java // RoleService.java public class RoleService { @Autowired private RoleMapper roleMapper; public void addNewRole(Role newRole){ // 调用 Mapper 方法之前 roleId 应该为空或默认值 System.out.println("Before insertion, the generated ID is: " + newRole.getRoleId()); try{ roleMapper.addRole(newRole); // 成功插入后的newRole 对象应当已经包含了由数据库分配的新主键 System.out.println("After successful insertion, the generated ID is now: " + newRole.getRoleId()); } catch(Exception e){ // 处理异常... } } } ``` 上述示例说明了通过适当配置MyBatis映射文件,并配合合理的编程实践,能够轻松实现在插入操作结束后立即访问所生成的主键值的功能[^5]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值