博客
关于我
关于Mybatis插入数据返回主键的问题
阅读量:543 次
发布时间:2019-03-09

本文共 1012 字,大约阅读时间需要 3 分钟。

遇到需要为新记录生成主键ID的MySQL插入操作问题时,有时简单的需求也会让我略微焦虑。记得以前做过类似的功能,但时光流逝具体实现细节也随之 görev,越简单的需求感觉越容易忘记细节。于是,就直接来看代码怎么做。

首先,查看一下数据库XML映射文件的配置。需要注意的是,在插入操作中如果需要自动生成主键ID,一定要配置好useGeneratedKeys="true"keyProperty="id"这两个属性。这些配置告诉数据库在插入新记录时,自动为记录生成唯一的主键ID,并将其指定为id字段。要注意的是,如果没有配置这些属性,可能会遇到主键生成失败或者重复的错误。

具体来看数据库XML映射文件中插入语句的配置:

INSERT INTO exam (user_id, total_num, correct_num, error_num, create_time) VALUES (#{ userId }, #{ totalNum }, #{ correctNum }, #{ errorNum }, #{ createTime })

可以看到,usegeneratedkeys="true"keyproperty="id"这两个属性配置正确后,插入操作就会自动为新插入的记录生成唯一的主键ID,并将其存储到数据库中。

然后,再看一下Java代码如何操作这一块。调用上述插入方法后,期望返回的新记录的ID可以通过exam.getId()来获取。具体实现如下:

examService.create(exam);Long id = exam.getId();

总体来看,关键在于XML映射文件中插入操作的配置是否正确。在实际应用中,要确保以下几点:

  • XML映射文件中插入操作配置带有usegeneratedkeys="true"keyproperty="id",否则主键ID不会自动生成
  • 确保数据库表examid字段被定义为主键代理列(auto_incrementidentity
  • Java对象的getId()方法返回的是数据库生成的主键值
  • 遇到类似问题时,只需要注意上述几点,就能顺利实现需求。数据库的自增列功能确实是个省心的特性,只要配置对,程序就能很容易地获取到新的记录ID。

    转载地址:http://yfgiz.baihongyu.com/

    你可能感兴趣的文章
    Netty工作笔记0008---NIO的Buffer的机制及子类
    查看>>
    Netty工作笔记0009---Channel基本介绍
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0013---Channel应用案例4Copy图片
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0015---MappedByteBuffer使用
    查看>>
    Netty工作笔记0020---Selectionkey在NIO体系
    查看>>
    Netty工作笔记0022---NIO快速入门--编写客户端
    查看>>
    Vue踩坑笔记 - 关于vue静态资源引入的问题
    查看>>
    Netty工作笔记0024---SelectionKey API
    查看>>
    Netty工作笔记0025---SocketChannel API
    查看>>
    Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
    查看>>
    Netty工作笔记0028---NIO 网络编程应用--群聊系统3--客户端编写1
    查看>>
    Netty工作笔记0034---Netty架构设计--线程模型
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0057---Netty群聊系统服务端
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0063---WebSocket长连接开发2
    查看>>
    Netty工作笔记0068---Protobuf机制简述
    查看>>
    Netty工作笔记0070---Protobuf使用案例Codec使用
    查看>>