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

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.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

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

    连续性 插入成功时,其数据 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 怎么产生隐藏主键 和 还要不要学MySQL

    首先invisible primary key是MySQL 8.030推出GIPK 功能,主要原因在一些程序设计中,的确忽略了主键设计,但基于mysql原理和推行 innodb cluster...部分对于表主键强需求,MySQL一直是不允许有没有主键情况,基于这些原因,所有推出了 invisible primary key ....下图中我们可以看到,如果在原有的语句中,来建立没有主键表是不能建立,会报错,因为MYSQL会自动建立主键并且是自增,所以不允许没有主键同时还建立自增字段,直接在建立时候就报错。...,没有新建表没有任何主键。...= GENERATE 方式,使副本在给定复制通道中为没有主键复制表添加生成不可见主键

    9410

    Mysql资料 主键

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

    3.8K20

    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强制实施规则(主键不可重复;一行中主键不可为空)之外,主键设计和应用应当还遵守以下公认原则: 不更新主键列中值; 不重用主键值; 不在主键列中使用可能会更改值...3、ID作为主键时在特定环境会存在一些问题,比如需要排序时候——UUID是无序。 4、MySQL官方有明确建议主键要尽量越短越好,36个字符长度UUID不符合要求。...5、对MySQL索引不利:作为数据库主键,在InnoDB引擎下,UUID无序性可能会引起数据位置频繁变动,严重影响性能。...关于MySQL 使用自增ID主键和UUID 作为主键性能比较可以查看参考【8】。 结论: 1、uuid做主键适用于小规模分布式架构用。...结论: 用自建id生成器做主键适用于大规模分布式架构 参考: 【1】:红心李 :MySQL主键设计 【2】:Uncle Nucky :MySQL数据库主键设计原则 【3】:ellis:设计套路:Mysql

    4.2K30

    MySQL主键约束使用

    MySQL主键约束是一种用于确保表中每行数据唯一性限制。每个表只能有一个主键,它可以是一个或多个列。创建表时添加主键约束在创建表时添加主键约束,需要在列名后面添加关键字"PRIMARY KEY"。...需要注意是,在修改表结构时,必须将该列中已经存在值都设置为唯一,否则会出现错误。主键约束和自增列通常情况下,主键约束通常与自增列一起使用。自增列是指在插入新行时,自动为该行分配一个唯一值。...在MySQL中,可以使用AUTO_INCREMENT关键字来创建自增列。...这意味着在插入数据时,无需提供"id"列值,MySQL会自动为其分配一个唯一值。示例假设有一个用户表,其中包含以下列:id、name和email。...,MySQL会自动为其分配一个唯一值。

    2.6K20

    mysql面试题43:MySQL自增主键用完了怎么办?

    该文章专注于面试,面试只要回答关键点即可,不需要对框架有非常深入回答,如果你想应付面试,是足够了,抓住关键点 面试官:MySQL自增主键用完了怎么办?...当MySQL自增主键用完了(达到了最大值),可以考虑以下几种解决方案: 1.扩大数据类型: 如果你自增主键数据类型是整数,例如INT,你可以考虑将数据类型扩大为更大整数类型,例如BIGINT...这将允许你有更大范围自增主键值。但是,注意要确保这个数据类型取值范围足够大,以满足你需求。...2.重新设计主键: 如果自增主键用完了,你可以考虑重新设计表主键,使用其他类型主键,例如UUID(通用唯一标识符)或字符串。这样主键不会受限于整数最大值,但可能会导致索引性能下降。...3.循环使用主键值: 如果你确定自增主键用完后不会再插入新数据,你可以考虑从头开始使用自增主键值,即将主键值循环使用。这样可以继续使用原来主键列,但要小心避免主键冲突。

    18100

    面试官:MySQL自增主键用完了怎么办?

    在面试中,大家应该经历过如下场景 面试官:"用过mysql吧,你们是用自增主键还是UUID?" 你:"用是自增主键" 面试官:"为什么是自增主键?"...你:"因为采用自增主键,数据在物理结构上是顺序存储,性能最好,blabla…" 面试官:"那自增主键达到最大值了,用完了怎么办?" 你:"what,没复习啊!!"...这个问题是一个粉丝给我提,我觉得挺有意(KENG)思(B)! 于是,今天我们就来谈一谈,这个自增主键用完了该怎么办! 正文 简单版 我们先明白一点,在mysql中,Int整型范围如下 ?...然而,如果你在面试中回答如果是 你:"简单啊,把自增主键类型改为BigInt类型就好了!" 接下来,面试官可以问你一个更坑问题! 面试官:"你在线上怎么修改列数据类型?"...怎么改 目前业内在线修改表结构方案,据我了解,一般有如下三种 方式一:使用mysql5.6+提供在线修改功能 所谓mysql自己提供功能也就是mysql自己原生语句,例如我们要修改原字段名称及类型

    9.1K31

    MySQL主键为0和主键自排约束关系

    开始不设置主键设计如下: 如果id位置有好几个0的话:设置主键并且自动排序时,0会从1开始递增; Insert 进去 id = 0数据,数据会从实际行数开始增加,和从0变化不一样;...我觉得也就这几种情况吧,无符号情况应该没什么区别,还有什么没有考虑希望大家给我留言,可以告诉我你是怎么,我也很想知道,现在抛砖引玉我把我总结和想法写一下:   对我来说,0在数据库里很特殊。...如果把表中某个主键数改成0,那直接就会进行排序放到正数前面,也就是说主键自排是允许有0存在,那为什么本身存在0要去修改成从1开始递增序列呢?...开始没0,增加主键自排约束,新添加主键是0行会根据行数自行变化,注意这里是新添加行,使用是insert。   开始没0,把某个主键数修改成0,这个0会直接在排好序了再在表里显示出来。...说得简单一点就是,增加主键自排约束后:    主键值:修改成0,可以存在,就是排个序。         新添加0,不允许存在,要根据行号改变。

    4.3K30

    Mysql:小主键,大问题

    本篇讲解 Mysql 主键」问题,从「为什么」角度来了解 Mysql 主键相关知识,并拓展到主键生成方案问题。再也不怕被问到 Mysql 时只知道 CRUD 了。...但这么点磁盘空间相对整个数据量来说微不足道,而且我们一般不怎么用到主键列。那么原因应该在「快」上,而且和原始数据关系不大。以此自然得出和「索引」相关,而且和索引读取相关。...这就要求同一个叶子节点内(大小为一个内存页或磁盘页)各条数据记录「按主键顺序存放」,因此每当有一条新记录插入时,MySQL 会根据其主键将其插入适当节点和位置,如果页面达到装载因子(InnoDB...否则由于每次插入主键值近似于随机,因此每次新记录都要被插到现有索引页中间某个位置,MySQL 不得不为了将新记录插到合适位置而「移动数据」,如下图右侧所示,这样就造成了一定开销。...一般情况下,我们都使用 Mysql 自增 ID,来作为表主键」,这样简单,而且从上面讲到来看,性能也是最好

    3.8K10

    大战MySQL主键及其操作

    简忆上次所学知识:MySQL记录长度为65535个字节,而varchar是达不到它理论长度,NULL占用一个字节,text文本不占用记录长度,因为它本身就占据十个字节。...这里继续学习与MySQL列属性相关知识:关于主键增,改,删。...主键 主键:primary key (一张表中最多只能有一个主键主键,简而言之为主要键,一张表中只能有一个字段可以使用对应键,用来约束该字段里面的数据,不能重复,被称之为主键 。...运行结果:PRI代表主键(大部分时候),NULL为no,即主键本身不为空 二.创建表时候,在字段之后,可以使用primary key(主键字段列表)来创建(如果有多个字段作为主键,可以称之为复合主键...主键约束(修改数据) 主键对应字段中数据不允许重复:一旦重复,数据操作就会失败(增和改) 相关语句: -- 向表中插入数据 insert into my_pril values ('小明','itcast0001

    4.4K20

    MySQL日期时间计算速查表

    最近写个SQL逻辑,涉及到计算各种日期和时间,MySQL提供了很丰富函数来支持,记录一下,用时候,有地方可查。...%a 缩写星期名 %b 缩写月名 %c 月,数值 %D 带有英文前缀月中天 %d 月天,数值(00-31) %e 月天,数值(0-31) %f 微秒 %H 小时 (00-23) %h 小时 (01...%u 周 (00-53) 星期一是一周第一天 %V 周 (01-53) 星期日是一周第一天,与 %X 使用 %v 周 (01-53) 星期一是一周第一天,与 %x 使用 %W 星期名 %w 周天...(0=星期日, 6=星期六) %X 年,其中星期日是周第一天,4 位,与 %V 使用 %x 年,其中星期一是周第一天,4 位,与 %v 使用 %Y 年,4 位 %y 年,2 位 QUARTER...():函数返回给定日期值(1到4之间数字)一年中季度, 语法:QUARTER(date) date,必须项。

    1.8K20

    为什么MySQL主键查询这么快

    能啊,这篇文章题目就是关于主键啊,我们可以按照主键顺序,从小到大来串联当前数据页中所有记录。事实上,MySQL设计者也确实是这么设计。...如果你足够叛逆,你可能会想,你不设置主键的话是不是MySQL就崩了啊?...Supremum伪记录所在分组记录条数只能在1~8条之间其余分组记录条数只能在4~8条之间规则是这样,可是InnoDB怎么确定每个组内有多少个组员呢?...但是对于我们这篇文章主题——MySQL主键查询为什么这么快,只能算是回答了一半,毕竟在数据页中进行搜索前提是你得先找到数据页啊。这就是每次面试必问MySQL索引知识了,下一篇文章再介绍吧。...数据页其他字段最后再补充几个知识点,文章中有两个问题我并没有讲槽是怎样被存储?二分查找时候,怎么知道目前有几个槽呢?

    4K92
    领券