首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

【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赋值给将要插入记录的主键

1.9K20
您找到你想要的搜索结果了吗?
是的
没有找到

MyBatis插入数据返回主键id

最近开发全栈项目时,前端有个数据行可以被随便修改,所以必须给他一个标识记录该数据行,即向MySQL数据库中插入一条记录后,需要获取此条记录的主键id值返回给前端。...content,name) values(#{articleTitle},#{articleCreateDate},#{articleContent},#{addName}) insert> 这种方式只是返回一个影响行数值...) 关键属性 useGeneratedKeys 仅适用于 insert 和 update,这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 方法来取出由数据库内部生成的主键...(比如MySQL的自动递增主键字段),默认值:false。...所以要打开设为 true keyProperty 仅适用于 insert 和 update,指定能够唯一识别对象的属性,MyBatis 会使用 getGeneratedKeys 的返回值或 insert

1.7K10

Mysql高效插入更新数据

从tushare抓取到的财务数据,最开始只是想存下来,用的办法想简单点,是:插入--报错—update 但发现这个方法太蠢,异常会导致大量无效连接,改为: for idx,row in...fldname,row[colname],row["code"],dat) except: log.errorlogger().exception("数据入库错误...运行没啥大问题,但就是太慢,取两年数据,万条左右,一早上还没全部入库。...只得研究优化,结果发现mysql居然有专门的语法,可以插入记录,遇到重复记录则为自动更新: ON DUPLICATE KEY UPDATE 上面的处理直接用一条sql语句就解决了: INSERT INTO...: # d2:待入库dataframe,第一列为code,第二列为数值 # dat:时间 # fldname:数据在库中的字段名 def addtodb(d2,dat,fldname):

2.7K50

Mysql高效插入更新数据

从tushare抓取到的财务数据,最开始只是想存下来,用的办法想简单点,是:插入--报错—update 但发现这个方法太蠢,异常会导致大量无效连接,改为: for idx,row in...fldname,row[colname],row["code"],dat) except: log.errorlogger().exception("数据入库错误...运行没啥大问题,但就是太慢,取两年数据,万条左右,一早上还没全部入库。...只得研究优化,结果发现mysql居然有专门的语法,可以插入记录,遇到重复记录则为自动更新: ON DUPLICATE KEY UPDATE 上面的处理直接用一条sql语句就解决了: INSERT INTO...: # d2:待入库dataframe,第一列为code,第二列为数值 # dat:时间 # fldname:数据在库中的字段名 def addtodb(d2,dat,fldname):

3K70

MySQL 批量插入:如何不插入重复数据

知识这个东西,看来真的要温故而知新,一直不用,都要忘记了 业务很简单:需要批量插入一些数据数据来源可能是其他数据库的表,也可能是一个外部excel的导入 那么问题来了,是不是每次插入之前都要查一遍...向大数据数据库中插入值时,还要判断插入是否重复,然后插入。如何提高效率 看来这个问题不止我一个人苦恼过。...几百万的数据,不可能查出来,做去重处理 说一下我Google到的解决方案 1、insert ignore into 当插入数据时,如出现错误时,如重复数据,将不返回错误,只以警告形式返回。...例如,为了实现name重复的数据插入不报错,可使用一下语句: INSERT INTO user (name) VALUES ('telami') ON duplicate KEY UPDATE id =...user (name) SELECT 'telami' FROM dual WHERE NOT EXISTS (SELECT id FROM user WHERE id = 1) 这种方法其实就是使用了mysql

3.6K20
领券