首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MyBatis + MySQL返回插入成功后的主键id

    这是最近在实现perfect-ssm中的一个功能碰到的一个小问题,觉得需要记录一下,向MySQL数据库中插入一条记录后,需要获取此条记录的id值,以生成对应的key值存入到redis中,id为自增int...add_name) values(#{articleTitle},#{articleCreateDate},#{articleContent},#{addName}) 这种方式只是返回一个影响行数值...,并不能满足此次需求,于是做了如下修改: <insert id="insertArticle" useGeneratedKeys="true" keyProperty="id" parameterType...=null); System.out.println("insert后article的id:"+article.getId()); } 结果如下: ?...mysql中表的记录如下: ? 结语 首发于我的个人博客,新的项目演示地址:perfect-ssm,登录账号:admin,密码:123456 ?

    4K60

    mybatis插入数据返回自增主键ID详解

    1.场景介绍: ​ 开发过程中我们经常性的会用到许多的中间表,用于数据之间的对应和关联.这个时候我们关联最多的就是ID,我们在一张表中插入数据后级联增加到关联表中.我们熟知的mybatis在插入数据返回的是插入成功的条数...2.插入数据返回自增主键ID方法(一) 在映射器中配置获取记录主键值 xml映射: 在xml中定义useGeneratedKeys为true,返回主键id的值,keyProperty和keyColumn...-- 插入数据:返回记录主键id值 --> ...System.out.println("id = " + student.getId()); // 执行添加操作之后通过Java对象获取主键属性值 添加批量记录返回主键ID 如果希望执行批量添加并返回各记录主键字段值...xml映射器配置,跟添加单条记录是一致的。

    12.3K30

    Mybatis使用generatedKey在插入数据返回自增id始终为1,自增id实际返回到原对象当中的问题排查

    今天在使用数据库的时候,遇到一个场景,即在插入数据完成后需要返回数据对应的自增主键id,但是在使用Mybatis中的generatedKey且确认各项配置均正确无误的情况下,每次插入成功后,返回的都是...终于凭借着一次Debugg发现的问题,原来在使用Mabatis中的insert或者insertSelective方式插入时,如使用int insert(TestGenKey testGenKey)返回值...int表示的是插入操作受影响的行数,而不是指的自增长id,那么返回的自增id到底去哪里了呢?...通过下面的Debugg我们知道自增id返回到testGenKey的原对象中去了。 举例示范配置 数据库示例表  generator的配置文件 <jdbcConnection driverClass="com.<em>mysql</em>.jdbc.Driver"

    1.7K10

    Python3 操作 MySQL 插入一条数据返回主键 id的实例

    Python 中貌似并没有直接返回插入数据 id 的操作(反正我是没找到),但是我们可以变通一下,找到最新插入数据 #!...和 conn.insert_id() 一定要在 conn.commit() 之前 由于数据库的安全机制决定,其中一个进程执行完成一条语句,此时只有这个进程能看到数据。...如果想要其他的进程也能看到数据,就需要使用 conn.commit() 提交,这样就保证了多进程同时操作数据库而不会冲突 但是多线程并发插入的时候就不行了,因为多线程是共享数据的,而且在 Python...中并没有所谓的真正多线程,建议使用多进程 补充拓展:mysql插入一条数据后得到插入后的主键id值 ** 当我们涉及多表进行插入操作是,常常需要在程序中等到刚刚插入数据的主键Id, 便与进行多表关联...="id" SELECT LAST_INSERT_ID() AS id </selectKey 以上这篇Python3 操作 MySQL 插入一条数据返回主键 id的实例就是小编分享给大家的全部内容了

    2.9K10

    MySQL 数据库表格创建、数据插入及获取插入ID:Python 教程

    创建表格 要在MySQL中创建表格,请使用"CREATE TABLE"语句。 确保在创建连接定义了数据库的名称。...检查表格是否存在 您可以通过使用"SHOW TABLES"语句列出数据库中的所有表格来检查表格是否存在: 示例返回系统中的表格列表: import mysql.connector mydb = mysql.connector.connect...executemany() 方法的第二个参数是包含要插入数据的元组列表: 示例填充 "customers" 表格的数据: import mysql.connector mydb = mysql.connector.connect...获取插入ID 您可以通过询问游标对象来获取刚刚插入的行的ID。 注意:如果插入多行,将返回最后插入行的ID。...示例插入一行,并返回ID: import mysql.connector mydb = mysql.connector.connect( host="localhost", user="yourusername

    28320

    SQL Server 返回最后插入记录的自动编号ID

    当将某行插入 T1 ,触发器被激发,并在 T2 中插入一行。此例说明了两个作用域:一个是在 T1 上的插入,另一个是作为触发器的结果在 T2 上的插入。...@@IDENTITY 返回插入到当前会话中任何作用域内的最后一个 IDENTITY 列值,该值是插入 T2 中的值。...SCOPE_IDENTITY() 返回插入 T1 中的 IDENTITY 值,该值是发生在相同作用域中的最后一个 INSERT。...如果在作用域中发生插入语句到标识列之前唤醒调用 SCOPE_IDENTITY() 函数,则该函数将返回 NULL 值。...SELECT IDENT_INCR(‘TableName’)–返回指定表的标示字段增量值 SELECT IDENT_SEED(‘TableName’)–返回指定表的标示字段种子值 返回最后插入记录的自动编号

    2.2K40

    【MyBatis框架点滴】——mybatis插入数据返回主键(mysql、oracle)

    主键的值都是插入之前无法知道的,但很多情况下我们在插入数据后需要使用刚刚插入数据的主键,比如向两张关联表A、B中插入数据(A的主键是B的外键),向A表中插入数据之后,向B表中插入数据需要用到A的主键。...id }   这里总结一下mybatis插入数据返回主键的4种情况:mysql环境下主键自增、mysql环境下主键为uuid、mysql环境下主键自增、mysql环境下主键为uuid。   ...数据库为mysql ---- 主键为自增(主键为数值类型且自增)   利用mysql的LAST_INSERT_ID()方法获取插入记录的主键,select LAST_INSERT_ID()可以在插入数据后...,查询并返回插入数据的主键(但是单独执行这条语句只会返回0)。...主键为UUID(主键必须为字符类型)   使用mysql的方法UUID()方法获取随机的UUID作为主键,select UUID()可以在插入数据前,生成随机的UUID并通过keyProperty赋值给将要插入记录的主键

    2K20

    MyBatis在insert插入对象返回自增主键

    首先你要确定几点 1: 你数据表的ID 是不是 设置了自增?如果没有,那么一切都是徒劳 2: 必须的几个属性你添加了么?...useGeneratedKeys="true"(默认是false) keyProperty="id" 3: keyProperty 这个设置的是 你传入对象的属性名,不是你数据表的字段 如果以上情况都满足...,那么你很有可能犯了一个和我一样的错误 网上大部分教程在写 insert对象并返回自增主键的 demo 的时候,都是直接传入对象,而没有用@Param注解 其实他们的区别在这里 keyProperty...="id" 如果你不用 @Param注解 ,那么你在 #{xxx}里写的是 对象的属性 如果你使用 @Param注解,那么相当于你给参数对象 命名了,那么你在#{xxx}里写的就是 命名参数.属性 但是你忘了

    2.2K20

    MySQL 插入数据

    MySQL 插入数据 MySQL 表中使用 INSERT INTO SQL语句来插入数据。 你可以通过 mysql> 命令提示窗口中向数据表中插入数据,或者通过PHP脚本来插入数据。...---- 通过命令提示窗口插入数据 以下我们将使用 SQL INSERT INTO 语句向 MySQL 数据表 runoob_tbl 插入数据 实例 以下实例中我们将向 runoob_tbl 表插入三条数据...在以上实例中,我们并没有提供 runoob_id数据,因为该字段我们在创建表的时候已经设置它为 AUTO_INCREMENT(自动增加) 属性。 所以,该字段会自动递增而不需要我们去设置。...实例中 NOW() 是一个 MySQL 函数,该函数返回日期和时间。...该函数有两个参数,在执行成功返回 TRUE,否则返回 FALSE。

    4.7K20
    领券