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

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

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

2K20

MySQL主键详解

表中任何列都可以作为主键,只要它满足以下主键值规则条件: 任两行不具相同主键值 每行都必须具有一个主键值(主键列不允许NULL) 这里规则是MySQL本身强制实施。...除MySQL强制实施规则外,还应该坚持最佳实践: 不更新主键列中值 不重用主键值 不在主键列中使用可能会更改值 例如,如果使用一个名字作为主键以标识某个供应商,当该供应商合并和更改其 名字时...,必须更改这个主键) 联合主键 好处 可以直观看到某个重复字段记录条数 主键A跟主键B组成联合主键 主键A跟主键B数据可以完全相同,联合就在于主键A跟主键B形成联合主键是唯一。...联合主键体现在多个表上,复合主键体现在一个表中多个字段。 复合主键 主键通常定义在表一列上,但这并不是必需,也可使用多个列作为主键。...表主键含有一个以上字段组成,不使用无业务含义自增id作为主键 将多个字段设置为主键,形成复合主键,这多个字段联合标识唯一性,其中,某几个主键字段值出现重复是没有问题,只要不是有多条记录所有主键值完全一样

4.9K20

mysql 联合主键_Mysql 创建联合主键

Mysql 创建联合主键 2008年01月11日 星期五 下午 5:21 使用primary key (fieldlist) 比如: create table mytable ( aa int, bb...char(8), cc date, primary key (aa,bb ) ); aa,bb为联合主键 不知道是不是因为mysql(6.0)版本问题,还是各版本都是这种情况,mysql中创建联合主键...TABLE t1( id … MySQL创建双主键 如下: CREATE TABLE `loginlog` ( `id` ) unsigned zerofill NOT NULL AUTO_INCREMENT...COMMENT ‘主键编号’, `IP` … mysql修改联合主键 参考 https://blog.csdn.net/BockSong/article/details/80933477 alter...涉及知识点总结如下: One to One 映射关系 一对一单向外键(XML/Annotation) 一对一双向外键关联(XML/A … SQL Server中联合主键、聚集索引、非聚集索引、mysql

8.2K20

mysql 主键自增语句_MySQL 自增主键

自增主键有两个性质需要考虑: 单调性 每次插入一条数据,其 ID 都是比上一条插入数据 ID 大,就算上一条数据被删除。...连续性 插入成功时,其数据 ID 和前一次插入成功时数据 ID 相邻。 自增主键单调性 为何会有单调性问题? 这主要跟自增主键最大值获取方式,以及存放位置有关系。...MySQL 5.7 及之前版本,自增主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算...从 MySQL 8.0 开始,自增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里值。...参考文档 为什么 MySQL 自增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

10.8K10

Mysql资料 主键

表中任何列都可以作为主键,只要它满足以下条件: 1、任何两行都不具有相同主键值 2、每个行都必须具有一个主键值(主键列不允许NULL值) 除MySQL强制实施规则外,应该坚持几个普遍认为最好习惯为...这就要求同一个叶子节点内(大小为一个内存页或磁盘页)各条数据记录按主键顺序存放,因此每当有一条新记录插入时,MySQL会根据其主键将其插入适当节点和位置,如果页面达到装载因子(InnoDB默认为15.../16),则开辟一个新页(节点) 1.如果表使用自增主键,那么每次插入新记录,记录就会顺序添加到当前索引节点后续位置,当一页写满,就会自动开辟一个新页。...2、.如果使用非自增主键(如果身份证号或学号等),由于每次插入主键值近似于随机,因此每次新纪录都要被插到现有索引页得中间某个位置: 此时MySQL不得不为了将新记录插到合适位置而移动数据,甚至目标页面可能已经被回写到磁盘上而从缓存中清掉...如果没有显式地在表定义时指定主键,InnoDB存储引擎会为每一行生成一个6字节ROWID,并一次作为主键mysql 在频繁更新、删除操作,会产生碎片。而含碎片比较大表,查询效率会降低。

3.8K20

MyBatis插入数据后返回主键id

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

1.7K10

mysql主键自增策略_MySQL 自增主键机制

大家好,又见面了,我是你们朋友全栈君。 自增主键:特指在自增列上定义主键。 自增主键优点是让主键索引保持递增顺序插入,避免页分裂,索引更加紧凑。 1. 自增值保存在哪?...不同存储引擎保存自增值策略不一样; a. 对于MyISAM引擎,自增值保存在数据文件中; b. Innodb引擎,mysql5.7之前,自增值保存在内存中,而且不会持久化自增值。...每次重启后第一次打开表,都会去查找自增值最大值max(id), 并设置表当前自增值为max(id) + 1; mysql8.0, 自增值变更记录在了redo log中,重启时依靠redo log恢复重启之前值...自增值修改发生在插入数据操作之前,如果插入失败,自增值不会再修改回去; b. 事务回滚也不会将自增值修改回去; c. 为了减少自增id锁带来性能影响,mysql不会修改回去之前自增值; 4....而对于批量插入数据语句(select … insert,replace … select 和 load data 语句),MySQL 有一个批量申请自增 id 策略(注:该策略是导致自增 id 不连续第三种原因

9.4K50

MySQL主键设计盘点

主键设计和应用原则 除了满足MySQL强制实施规则(主键不可重复;一行中主键不可为空)之外,主键设计和应用应当还遵守以下公认原则: 不更新主键列中值; 不重用主键值; 不在主键列中使用可能会更改值...主键生成策略 自增ID 使用数据库自动增长(auto_increment),是比较简单和常见ID生成方案,数据库内部可以确保生成id唯一性。...优点: 1、数据库自动编号,速度快,而且是增量增长,聚集型主键按顺序存放,对于检索非常有利。 2、 数字型,占用空间小,易排序,在程序中传递方便。...关于MySQL 使用自增ID主键和UUID 作为主键性能比较可以查看参考【8】。 结论: 1、uuid做主键适用于小规模分布式架构用。...结论: 用自建id生成器做主键适用于大规模分布式架构 参考: 【1】:红心李 :MySQL主键设计 【2】:Uncle Nucky :MySQL数据库主键设计原则 【3】:ellis:设计套路:Mysql

4.2K30
领券