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

面试突击57:聚簇索引=主键索引

一般情况下,聚簇索引等同于主键索引,但这里有一个前提条件,那就是这张表需要有主键,只有有了主键,它才能有主键索引,有主键索引才能等于聚簇索引。...所以看到这里,我们应该明白一个道理:聚簇索引并不完全等于主键索引,因为一张表从结构上来讲,可以没有主键索引),如果没有主键索引),那么聚簇索引就不再是主键索引了。...通常情况下,我们应该为一张表设置一个主键,如果没有合适的列作为主键列,我们可以定义一个自动递增的唯一列为主键,并且在插入数据时是自动填充此列。...然而,如果一张表中没有设置主键,那么 InnoDB 会使用第一个唯一索引(unique),且此唯一索引设置了非空约束(not null),我们就使用它作为聚簇索引。...参考 & 鸣谢 dev.mysql.com/doc/refman/5.7/en/innodb-index-types.html 是非审之于己,毁誉听之于人,得失安之于数。

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

主键索引就是聚集索引MySQL 索引类型大梳理

之前松哥在前面的文章中介绍 MySQL索引时,有小伙伴表示被概念搞晕了,主键索引、非主键索引、聚簇索引、非聚簇索引、二级索引、辅助索引等等,今天咱们就来捋一捋这些概念。 1....全文索引MySQL 中支持的版本也需要大家留意一下: MySQL 5.6 以前的版本,只有 MyISAM 存储引擎支持全文索引。...MySQL 5.6 及以后的版本,MyISAM 和 InnoDB 存储引擎均支持全文索引。...MySQL 的全文索引最开始只支持英文,因为英文分词比较方便;中文分词就比较麻烦,所以最早的 MySQL 全文索引是不支持中文的。...不过 MySQL 的全文索引并不好用,有这方面的需求还是直接上 Es 吧。

2.2K20

mysql 唯一索引_mysql主键和唯一索引的区别

Mysql索引大概有五种类型: 普通索引(INDEX):最基本的索引,没有任何限制 唯一索引(UNIQUE):与”普通索引”类似,不同的就是:索引列的值必须唯一,但允许有空值。...主键索引(PRIMARY):它 是一种特殊的唯一索引,不允许有空值。...联合(组合)索引:为了更多的提高mysql效率可建立组合索引,遵循”最左前缀“原则。 这里我们来看下唯一索引。...之前我们看了主键索引,他是一种特殊的唯一索引,二者的区别是,主键索引不能有空值,但是唯一索引可以有空值。...单列唯一值基本上就是主键。 常用的一般都是多列的唯一索引,比如:当前商品,一个用户只能购买一件。我们将用户id及商品id列设置成唯一索引。那么就可以避免一个用户出现重复购买的情况。

2.7K30

mysql 设置主键命令_MySQL常用命令

那么password字段要改成authentication_string 创建数据库用户: 单纯的创建:create user ‘name’@‘host’ identified by ‘密码’ 创建时设置用户权限...10,不允许该字段为空 删除:drop table 表名称 drop table test 4、表中插入数据 insert into test(id) values(1002); #此处注意如果字段值设置为...方式一: 创建表时创建主键:create table test(id int(10),name char(20),primary key id); 方式二: 创建完表之后添加主键:alter table...userinfo add primary key (id); 删除主键:alter table userinfo drop primary key; 9、创建索引 方式一: 创建表时创建索引:create...table userinfo add index user(name); #user表示索引名称,自定义 删除索引:alter table userinfo drop index user; 10、常用查询命令

3.8K20

MySQL ORDER BY主键id加LIMIT限制走错索引

背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49的时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...,大于49时就走PRIMARY主键索引。...在order by 主键id时,limit值的大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体的规则究竟是怎样。...由于自身的优化器选择,为了避免某些排序的消耗,可能会走非预期的PRIMARY主键索引; order by 和 limit 结合使用,如果where 字段,order by字段都是索引,那么有limit索引会使用...查看是否使用到了最优索引; 利用optimizer trace查看优化器执行过程; 观察mysql的slow_query_log,及时做排查优化。

1.8K10

oracle删除主键索引的sql语句_oracle主键索引和普通索引

for enforcement of unique /primary key 这个错误,对应的中文提示“ORA-02429: 无法删除用于强制唯一/主键索引”,其实从错误提示信息已经很明显了。...ORA-02429错误的原因是因为用户试图删除一个用于强制唯一/主键索引,解决方法也很简单,删除对应的约束就会自动删除该索引。...&设置某一字段可以为null 1.oracle主键修改 1.1)首先查看需要修改的表的主键名,默认的情况下,数据库会自动分配 select * from user_cons_columns where...1.2)删除主键约束 alter table 表名 drop constraint 主键名(通过上一步查找出来) 1.3)添加主键约束 alter table 表名 add constraint 主键名...primary key(字段名1,字段名2...); 主键名命名规则建议为pk_表名 2.oracle设置字段可以为空 alter table 表名 modify 字段名 null; 版权声明:本文内容由互联网用户自发贡献

3.8K10

MySQL ORDER BY主键id加LIMIT限制走错索引

背景及现象 report_product_sales_data表数据量2800万; 经测试,在当前数据量情况下,order by主键id,limit最大到49的时候可以用到索引report_product_sales_data_hq_code_orgz_id_index...,大于49时就走PRIMARY主键索引。...在order by 主键id时,limit值的大小达到了某个临界值后,改变了执行计划,选择了主键索引,但不知道具体的规则究竟是怎样。...由于自身的优化器选择,为了避免某些排序的消耗,可能会走非预期的PRIMARY主键索引; 对于数据量比较大,而且执行量很高的分页sql,尽可能将所有的查询字段包括在索引中,同时使用索引来消除排序; 多用explain...查看是否使用到了最优索引; 利用optimizer trace查看优化器执行过程; 观察mysql的slow_query_log,及时做排查优化。

6.6K32

Mysql 的Index 索引设置

索引是快速搜索的关键。MySQL索引的建立对于MySQL的高效运行是 很重要的。对于少量的数据,没有合适的索引影响不是很大,但是,当随着数据量的增加,性能会急剧 下降。...当创建索引带来的好处多过于消耗的时候,才是最优的选择~ # 查看索引 show index from quickchat_user_additional; 索引的类型 (具体设置在Navicat中添加即可...) 主键索引 PRIMARY KEY 它是一种特殊的唯一索引,(设置主键底层就自动设置)了,不允许有空值。...一般是在建表的时候同时创建主键索引。 唯一索引 UNIQUE 唯一索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。可以在创建 表的时候指定,也可以修改表结构。...MYSQL使用SPATIAL关键字进行扩展,使得能够用于创建正规索引类型的语法创建空间索引

2K20

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中创建联合主键...COMMENT ‘主键编号’, `IP` … mysql修改联合主键 参考 https://blog.csdn.net/BockSong/article/details/80933477 alter...涉及的知识点总结如下: One to One 映射关系 一对一单向外键(XML/Annotation) 一对一双向外键关联(XML/A … SQL Server中的联合主键、聚集索引、非聚集索引mysql...联合索引 我们都知道在一个表中当需要2列以上才能确定记录的唯一性的时候,就需要用到联合主键,当建立联合主键以后,在查询数据的时候性能就会有很大的提升,不过并不是对联合主键的任何列单独查询的时候性能都会提升

8.2K20

主键、聚集索引、辅助索引

每张表都一定存在主键? 关于这个问题,各位小伙伴们不妨先自己想一想,再往下寻找答案。 首先公布结论:对于 InnoDB 存储引擎来说,每张表都一定有个主键(Primary Key)!...那下面这段没定义主键的建表语句是正确的?...主键和聚集索引的关系 先来看聚集索引,上面我们说过,InnoDB 存储引擎表是索引组织表结构,即表中数据都是按照主键顺序进行存放的。...一张表只能有一个主键,并且也只能有一个聚集索引,聚集索引还是按照主键来构建的,那这种种迹象不都表明主键就是聚集索引? 事实上,主键索引就不是一个层次的东西!...而至于 “主键就是索引” 这种观点的由来,是因为:InnoDB 存储引擎中,每张表都一定存在主键(显示或隐式),而聚集索引依赖于主键的建立,所以如果没有强制指定使用非聚集索引,InnoDB 在创建主键的同时会建立一个唯一的聚集索引

78910

MySQL聚簇索引物理结构及主键查询过程

数据页分裂的过程,在你不停往表里灌入数据时,会搞出来一个个数据页,若你的主键非自增,他可能会有一个数据行挪动过程,保证你下一个数据页的主键值都大于上一个数据页的主键值。...对此,就得针对主键设计个索引,针对主键索引实际上就是主键目录:把每个数据页的页号,还有数据页里最小的主键值放在一起,组成一个索引的目录 有了上图的主键目录就好多了,直接到主键目录搜索id=3的数据,...此时就会和每个数据页的最小主键来比,首先id=3大于了数据页2里的最小主键值1,接着小于了数据页8里的最小主键值4。...假设有很多数据页,在主键目录里就会有很多数据页和最小主键值,此时完全可二分查找待查询id在哪个数据页。 所以这效率很高,类似上图的主键目录就能认为是主键索引。...数据页都是一坨坨连续数据,放在很多磁盘文件,所以只要你能根据主键索引定位到数据所在的数据页,此时假设我们有别的方式存储了数据页跟磁盘文件的对应关系,此时你就可以找到一个磁盘文件。

1.2K20

唯一索引主键索引的比较

唯一索引 唯一索引不允许两行具有相同的索引值。 如果现有数据中存在重复的键值,则大多数数据库都不允许将新创建的唯一索引与表一起保存。当新数据将使表中的键值重复时,数据库也拒绝接受此数据。...例如,用户表中的身份证(idcard) 列上创建了唯一索引,则所有身份证不能重复 主键索引 主键索引是唯一索引的特殊类型。 数据库表通常有一列或列组合,其值用来唯一标识表中的每一行。...该列称为表的主键。 在数据库关系图中为表定义一个主键将自动创建主键索引主键索引是唯一索引的特殊类型。主键索引要求主键中的每个值是唯一的。当在查询中使用主键索引时,它还允许快速访问数据。...比较: 1对于主健/unique constraint , oracle/sql server/mysql等都会自动建立唯一索引; 2主键不一定只包含一个字段,所以如果你在主键的其中一个字段建唯一索引还是必要的...; 3主健可作外健,唯一索引不可; 4主健不可为空,唯一索引可; 5主健也可是多个字段的组合; 6主键与唯一索引不同的是: (1).有not null属性; (2).每个表只能有一个。

3K110

mysql 索引主键 外键等概念彻底理清楚

参考文章: Mysql 索引详解和优化 数据库原理-几种数据模型 Mysql中的key和index的区别 (讲的很合理) Mysql中的Cascade,NO ACTION,Restrict...,SET NULL几种功能说明 Mysql中key 、primary key 、unique key 与index区别 重点总结: 1、mysql 的特点: 括号里面是-类型,外面是-名字。...不存在歧义的概念: 1、 primary key 数据库的每张表只能有一个主键,不可能有多个主键。所谓的一张表多个主键,我们称之为联合主键。联合主键就是用多个字段一起作为一张表的主键。...主键主键的作用是保证数据的唯一性和完整性,同时通过主键检索表能够增加检索速度。 唯一性:列可以不唯一,但联合起来必须唯一。...2、 存在歧义的概念: key 和 索引index 1、索引—在SQL语句里叫 key 错综复杂的关系: 1、primary key 与 外键 一图理解: ?

2.5K10

主键、唯一索引、普通索引及约束

唯一索引是这样一种索引,它通过确保表中没有两个数据行具有完全相同的键值来帮助维护数据完整性。 换个说法,有了唯一索引就可以确保数据表不会有相同行数据(组成唯一索引键的列)....唯一键约束与唯一索引又有什么区别? 唯一键约束与唯一索引的区别只有一个:唯一键约束不允许空值的存在,而唯一索引是允许空值的存在的。 2....主键索引 (primary key) ALTER TABLE `table_name` ADD PRIMARY KEY (`id`); 主键索引,是一种特殊的唯一索引(不允许有空值)。...数据表通常用一列或多列来唯一标识行数据,这一列或多列就是主键。 Q:主键索引与唯一索引有啥区别呢? A:1. 主键不允许空值存在的;2. 一个表仅有一个主键。...参考 主键和唯一索引的区别 唯一索引和非唯一索引

4.5K30

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

自增主键最大值怎么取的?存放到哪里?...MySQL 5.7 及之前的版本,自增主键最大值会在启动(重启)后从数据库中取出放到内存: SELECT MAX(ai_col) FROM table_name FOR UPDATE; 这样获取是通过计算的...除非设置了外键。 比如我要向最大一个 ID 的账号充了 100 万。但是在充值之前,该账号被删除,然后服务器故障重启,重启后有人新注册了一个账号。结果我的 100 万充到了他的新账号上。...从 MySQL 8.0 开始,自增主键最大值会在每次修改后写入到 redo log,并且在每个检查点写入引擎私有的系统表。 如果是正常重启,则读取系统表里的值。...参考文档 为什么 MySQL 的自增主键不单调也不连续 https://database.51cto.com/art/202004/614923.htm 《MySQL技术内幕——InnoDB存储引擎》

10.8K10
领券