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

MySQL主键详解

没有主键,更新或删除表中特定行很困难,因为没有安全方法保证只涉及相关行而不误伤其他行! 一个顾客表可以使用顾客编号列,而订单表可以使用订单ID,雇员表可以使用雇员ID或雇员社会保险号。...表中任何列都可以作为主键,只要它满足以下主键值规则条件: 任两行不具相同主键值 每行都必须具有一个主键值(主键列不允许NULL) 这里规则是MySQL本身强制实施。...除MySQL强制实施规则外,还应该坚持最佳实践: 不更新主键列中值 不重用主键值 不在主键列中使用可能会更改值 例如,如果使用一个名字作为主键以标识某个供应商,当该供应商合并和更改其 名字时...表主键含有一个以上字段组成,不使用无业务含义自增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进阶学习之SQL优化【插入,主键,排序,分组,分页,计数】

    (比如: 几百万记录),使用insert语句插入性能较低,此时可以使用MySQL数据库提供load指令进行插入。...注:当删除一行记录时,实际上记录并没有被物理删除,只是记录被标记(flaged)为删除并且它空间变得允许被其他记录声明使用。...分组操作时,索引使用也是满足最左前缀法则。 5、limit优化 在数据量比较大时,如果进行limit分页查询,在查询时,越往后,分页查询效率越低。...我们一起来看看执行limit分页查询耗时对比: 通过测试我们会看到,越往后,分页查询效率越低,这就是分页查询问题所在。...服务层拿到主键后,直接按行进行累加(主键不可能为null) count(字 段) 没有not null 约束 : InnoDB 引擎会遍历整张表把每一行字段值都取出来,返回给服务层,服务层判断是否为null

    2.2K30

    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强制实施规则外,应该坚持几个普遍认为最好习惯为...,此时又要从磁盘上读回来,这增加了很多开销,同时频繁移动、分页操作造成了大量碎片,得到了不够紧凑索引结构,后续不得不通过OPTIMIZE TABLE来重建表并优化填充页面。...在使用InnoDB存储引擎时,如果没有特别的需要,请永远使用一个与业务无关自增字段作为主键。 InnoDB 存储引擎采用了聚集(clustered)方式,因此每张表存储都是按主键顺序进行存放。...如果没有显式地在表定义时指定主键,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.5K50

    mysql编写sql脚本:要求表没有主键,但是想查询没有相同值时候才进行插入

    init-table.sql脚本(这里面的轻易不动了,保持原结构数据),然后还有个用于后续迭代升级增量脚本sql,当然我们没有使用flayway技术,使用是python安装脚本解析读取执行。...(表没有主键,但是想查询没有相同值时候才进行插入)模板如果表没有主键,你可以使用 WHERE NOT EXISTS 子查询来在插入数据之前进行条件检查,确保没有相同值存在。...value1'、'value2' 是对应列值。在 WHERE NOT EXISTS 子查询中,我们检查表中是否存在与要插入值匹配记录。如果不存在,就会执行插入操作。...请注意,FROM dual 是一个虚拟表,在这里用于提供插入语句所需基础查询。你可以根据实际情况替换 'value1'、'value2' 和对应列名与值。...使用这种方法,只有当表中没有与要插入值匹配记录时,才会执行插入操作。否则,不会插入重复数据。

    6010

    MySQL主键设计盘点

    主键设计和应用原则 除了满足MySQL强制实施规则(主键不可重复;一行中主键不可为空)之外,主键设计和应用应当还遵守以下公认原则: 不更新主键列中值; 不重用主键值; 不在主键列中使用可能会更改值...优点: 性能非常高:本地生成,没有网络消耗。 ? 缺点: 1、不易于存储:UUID太长,16字节128位,通常以36长度字符串表示,很多场景不适用。...3、ID作为主键时在特定环境会存在一些问题,比如需要排序时候——UUID是无序。 4、MySQL官方有明确建议主键要尽量越短越好,36个字符长度UUID不符合要求。...关于MySQL 使用自增ID主键和UUID 作为主键性能比较可以查看参考【8】。 结论: 1、uuid做主键适用于小规模分布式架构用。...结论: 用自建id生成器做主键适用于大规模分布式架构 参考: 【1】:红心李 :MySQL主键设计 【2】:Uncle Nucky :MySQL数据库主键设计原则 【3】:ellis:设计套路:Mysql

    4.2K30

    MYSQL分页查询时没有用ORDER BY出现数据重复问题

    背景 产品反馈,用户在使用分页列表时,出现数据重复问题,查看代码后发现对应分页SQL并没有使用order by进行排序,但是印象中MysqlInnoDB引擎会默认按照主键id进行排序,本地测试了一下的确出现了部分数据在不同页都出现问题...如果没有定义 order by MySQL使用SELECT 语句不加ORDER BY默认是如何排序 那返回数据不一定是按照主键来排序,结果可以以任意顺序返回 - 也可能随着时间而改变。...对于同样一批数据,在某一个时刻顺序是一样,随着时间变化,数据会发生变化,那么在进行查询时候,MySQL 会尝试以尽可能快方法(MySQL 实际方法不见得快)返回数据。...由于访问主键、索引大多数情况会快一些(在Cache里)所以返回数据有可能以主键、索引顺序输出,这里并不会真的进行排序,主要是由于主键、索引本身就是排序放到内存,所以连续输出时可能是某种序列。...然后回答你问题: •MySQL 根据需要对记录进行排序,但没有任何一致性保证•如果您打算依赖此顺序进行任何操作,则必须使用 order by 指定您想要顺序。

    1.6K11

    java mysql 分页_mysql分页查询总结

    mysql分页查询总结 mysql提供分页功能: SELECT * FROM table LIMIT [offset,] rows | rows OFFSET offset LIMIT子句可以被用于强制...如果给定两个参数,第一个参数指定第一个返回记录行偏移量,第二个参数指定返回记录行最大数目。初始记录行偏移量是 0(而不是 1)。下面,我们针对特例对mysql分页查询进行总结。...最简单用法就是: select * from table limit ?,? 这种是最简单limit分页查询。...以上两种情况,对于小数据量分页查询时,这样sql就足够用了。但是对于百万级以上数据表,如果使用上边sql 的话,越往后limit语句偏移量越来越大,查询就会变得越来越慢。...(但是,子查询需要在内存中建立临时表,查询完毕后,MySQL需要撤销这些临时表。

    3.7K20

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

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

    4.3K30

    Mysql:小主键,大问题

    本篇讲解 Mysql 主键」问题,从「为什么」角度来了解 Mysql 主键相关知识,并拓展到主键生成方案问题。再也不怕被问到 Mysql 时只知道 CRUD 了。...所以体现在数据存储上,「主键第二作用,也是存在第二因素即: 「2.数据需要关联」 「数据」用于描述客观实在,本身没有意义。...业务 Key 缺点 当业务发生变化时,有时需要变更主键 涉及多列 Key 时比较难操作 业务 Key 往往比较长,所占空间更大,导致更大磁盘 IO 在 Key 确定前不能持久化数据,有时我们没有在确定数据...Key 往往更小,性能更优 逻辑 Key 更容易保证唯一性 更易于优化 逻辑 Key 缺点 查询主键列和主键索引需要额外磁盘空间 在插入数据和更新数据时需要额外 IO 更多 join 可能 如果没有唯一性策略限制...,容易出现重复 Key 测试环境和正式环境 Key 不一致,不利于排查问题 Key 没有和数据关联,不符合三范式 不能用于搜索关键字 依赖不同数据库系统具体实现,不利于底层数据库替换 五、主键生成

    3.8K10

    大战MySQL主键及其操作

    趣味杂谈 《原则》原文:但我不敢确信这场转型会顺利,因为我没有经历过这样事情。我做事方式是试错:犯错,找出错误原因,总结出新原则,最终成功。而我觉得应该以同样态度对待这场转型。...简忆上次所学知识:MySQL记录长度为65535个字节,而varchar是达不到它理论长度,NULL占用一个字节,text文本不占用记录长度,因为它本身就占据十个字节。...这里继续学习与MySQL列属性相关知识:关于主键增,改,删。...主键 主键:primary key (一张表中最多只能有一个主键主键,简而言之为主要键,一张表中只能有一个字段可以使用对应键,用来约束该字段里面的数据,不能重复,被称之为主键 。...运行结果:PRI代表主键(大部分时候),NULL为no,即主键本身不为空 二.创建表时候,在字段之后,可以使用primary key(主键字段列表)来创建(如果有多个字段作为主键,可以称之为复合主键

    4.4K20

    mysql自增主键设置

    mysql自增主键设置 在数据库应用中,经常希望在每次插入新纪录时,系统自动生成字段主键值。可以通过为表主键添加AUTO_INCREMENT关键字来实现。...默认情况下,在MYSQL中AUTO_INCREMENT初始值是1,每新增一条记录,字段值自动加1.一个表只能有一个字段属用AUTO_INCREMENT约束,且该字段必须为主键一部分。...AUTO_INCREMENT约束字段可以是任何整数类型(TINTINT、SMALLINT、INT、BIGINT等) 设置表属性值自动增加语法规则如下: 字段名 数据类型 AUTO_INCREMENT...执行插入语句: insert into tb_emp8(name,salary) values('lucy',1000),('lura',1200),('kevin',1500); 查看数据表 在这里并没有输入...id值,但系统已经自动添加该值

    11.1K30

    优化MySQL分页

    一道面试问题,当MySQL表中有数据量很大时候如何做分页。。。。当时只知道在数据量很大时候可以分表,但不知道不分表时可以怎么做。。。。...然而,如何通过MySQL更好实现分页,始终是比较令人头疼问题。虽然没有拿来就能用解决办法,但了解数据库底层或多或少有助于优化分页查询。 我们先从一个常用但性能很差查询来看一看。...实际上,这个查询语句和参数都没有问题,因为它用到了下面表主键,而且只读取15条记录。...大分页偏移量会增加使用数据,MySQL会将大量最终不会使用数据加载到内存中。就 算我们假设大部分网站用户只访问前几页数据,但少量分页偏移量请求也会对整个系统造成危害。...Facebook意识到了这一点,但 Facebook并没有为了每秒可以处理更多请求而去优化数据库,而是将重心放在将请求响应时间方差变小。 对于分页请求,还有一个信息也很重要,就是总共记录数。

    2.6K30
    领券