首先要明确一个概念,在聚集索引的世界里索引就是数据,在最后的叶子索引键保存着对应的数据行。...举个例子: 表TestNonclusteredIndex ID col1 1 4 2 5 3 6 4 7 其中ID列上有聚集索引,col1上是非聚集索引 执行下面语句: select...如果执行这条查询语句: select * from TestNonclusteredIndex where col1 = 6 SQL知道col1上有非聚集索引,去索引里查找,找到的是6的非聚集索引键值和这条记录的聚集索引键值...,因为没有数据(3 6),SQL就用这个聚集索引查找,就上面的例子一样就找到(3 6)这条数据; 其次,你要知道聚集索引是顺序的,到最后的数据页的时候,你知道第一条记录聚集索引是1难道聚集索引为2的记录不是它下一条...,那么聚集索引为N的记录不是1之后的N-1条?
MySQL 中,根据索引树叶结点存放数据行还是数据行的地址,可以将索引分为两类: 存放数据行:聚集索引 存放数据行地址:非聚集索引 InnoDB 使用聚集索引,MyISAM 使用非聚集索引。...1.聚集索引 1.1 介绍 聚集索引(Clustered Index)也叫聚簇索引,一般以主键建立索引。 在 InnoDB 中如果没有定义主键,会选择第一个非空唯一索引来代替。...1.2 优点 主键查询效率更高 通过主键使用聚集索引查找数据比非聚集索引要快,因为非聚集索引定位到对应主键时还要多一次目标记录磁盘 IO,即回表查询。...2.非聚集索引 按照语义,除了聚集索引,其他索引都是非聚集索引。 但在这里非聚集索引特指索引树叶结点存储的是「索引+数据地址」的索引。...一个表中只能有一个聚集索引,而非聚集索引可以有多个。 磁盘 IO 次数不同。 聚集索引通过一次索引查询可以直接找到数据,而非聚集索引需要一次索引查询到数据地址,外加一次数据磁盘 IO。
创建索引一般分为在线索引和非在线索引,在线与非在线的区别:非在线锁表,优先创建索引,此时DML都被阻塞,所以快;相反,在线锁的是行而非表,通过临时表进行索引的创建,所以不会影响DML操作,但副作用就是慢...如果在生产环境操作,不停服务的话,势必导致创建索引期间仍有DML操作进来。另外如果是大表,那么采用非在线而导致锁表所带来的影响可能会很大。一句话,生产环境不停服的脚本操作,建议使用online。...1、创建索引。...LOAD_ID, LOAD_STATUS, FACILITY_RRN) tablespace TBS_MY_INDEX pctfree 10 initrans 2 maxtrans 255; 2、创建在线索引...DROP INDEX 索引名; 4、查看某个表的索引,表名需大写。 SELECT * FROM ALL_INDEXES WHERE TABLE_NAME = '表名' 5、查看某个表哪些列有索引。
聚集索引和非聚集索引都可以是唯一的。 这意味着任何两行都不能有相同的索引键值。 另外,索引也可以不是唯一的,即多行可以共享同一键值。 有关详细信息,请参阅 创建唯一索引。...索引和约束 对表列定义了 PRIMARY KEY 约束和 UNIQUE 约束时,会自动创建索引。...例如,如果创建了表并将一个特定列标识为主键,则 数据库引擎 自动对该列创建 PRIMARY KEY 约束和索引。...对于包含 SELECT、UPDATE、DELETE 或 MERGE 语句的各种查询,索引会很有用。...但如果没有索引,则查询优化器必须扫描表。 您的任务是设计并创建最适合您的环境的索引,以便查询优化器可以从多个有效的索引中选择。
前面两个例子中都有主键索引的创建方式,我这里就不再列举了。...全文索引在 MySQL 中支持的版本也需要大家留意一下: MySQL 5.6 以前的版本,只有 MyISAM 存储引擎支持全文索引。...创建全文索引对字段类型也有要求,只有字段的数据类型为 CHAR、VARCHAR 以及 TEXT 等才可以建立全文索引。...MySQL 的全文索引最开始只支持英文,因为英文分词比较方便;中文分词就比较麻烦,所以最早的 MySQL 全文索引是不支持中文的。...当我们基于 InnoDB 引擎创建一张表的时候,都会创建一个聚集索引,每张表都有唯一的聚集索引: 如果这张表定义了主键索引,那么这个主键索引就作为聚集索引。
查询优化: 索引覆盖扫描——当索引中的列包含所有查询中要使用的列的时候,就会用到覆盖索引,效率比较高。 因为尽量使select后面的字段是where中的索引字段。
每张使用 InnoDB 作为存储引擎的表都有一个特殊的索引称为聚集索引,它保存着每一行的数据,通常,聚集索引就是主键索引。...If you do not define a PRIMARY KEY for your table, MySQL locates the first UNIQUE index where all the...如果你的表没有定义主键,InnoDB 会选择第一个唯一非空索引来作为聚集索引。...如果你的表既没有主键,又没有合适的唯一索引,InnoDB 内部会生成一个隐式聚集索引 —— GEN_CLUST_INDEX,该索引建立在由 rowid 组成的合成列上。...除了聚集索引外的其他索引类型都属于二级索引。在 InnoDB 中,二级索引中的每个记录都包含该行的主键列,以及二级索引指定的列;聚集索引中,InnoDB 通过主键值来查询数据行。
SQL Sever索引类型有:唯一索引,主键索引,聚集索引,非聚集索引。 MySQL 索引类型有:唯一索引,主键(聚集)索引,非聚集索引,全文索引。...因此在查询方面,聚集索引的速度往往会更占优势。 创建聚集索引 如果不创建索引,系统会自动创建一个隐含列作为表的聚集索引。...1.创建表的时候指定主键(注意:SQL Sever默认主键为聚集索引,也可以指定为非聚集索引,而MySQL里主键就是聚集索引) create table t1( id int primary key...(colum_name) MySQL alter table table_name add primary key(colum_name) 值得注意的是,最好还是在创建表的时候添加聚集索引,由于聚集索引的物理顺序上的特殊性...使用以下语句进行查询,不需要进行二次查询,直接就可以从非聚集索引的节点里面就可以获取到查询列的数据。
生成删除索引的 SQL 语句 mysql -uwxy -p12345 -S /data/18253/mysqldata/mysql.sock -e " select concat('alter table...生成创建索引的 SQL 语句 mysql -uwxy -p12345 -S /data/18253/mysqldata/mysql.sock -e " select concat('alter table...生成分析表的 SQL 语句 mysql -uwxy -p12345 -S /data/18253/mysqldata/mysql.sock -e " select concat('analyze table
1.PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 2.UNIQUE(唯一索引...) mysql>ALTER TABLE `table_name` ADD UNIQUE (`column` ) 3.INDEX(普通索引) mysql>ALTER TABLE `table_name...` ADD INDEX index_name ( `column` ) 4.FULLTEXT(全文索引) mysql>ALTER TABLE `table_name` ADD FULLTEXT...( `column` ) 5.多列索引 mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column1`, `column2`
聚集索引实际存放的示意图 从上图可以看出聚集索引的好处了,索引的叶子节点就是对应的数据节点(MySQL的MyISAM除外,此存储引擎的聚集索引和非聚集索引只多了个唯一约束,其他没什么区别),可以直接获取到对应的全部列的数据...因此在查询方面,聚集索引的速度往往会更占优势。 创建聚集索引 如果不创建索引,系统会自动创建一个隐含列作为表的聚集索引。...创建表的时候指定主键(注意:SQL Sever默认主键为聚集索引,也可以指定为非聚集索引,而MySQL里主键就是聚集索引) create table t1( id int primary key..., name nvarchar(255) ) 创建表后添加聚集索引 MySQL alter table table_name add primary key(colum_name) 值得注意的是...使用以下语句进行查询,不需要进行二次查询,直接就可以从非聚集索引的节点里面就可以获取到查询列的数据。
MySQL中索引的存储类型有两种:BTREE(树)和 HASH(哈希),具体和表的存储引擎有关。MyISAM和InnoDB存储引擎只支持BTREE索引。...;INDEX 与 KEY为同义词,两者的作用相同,用来指定索引; (1)、普通索引(index): 普通索引是MySQL的基本索引类型,允许在定义索引的列中插入重复值和空值 例: CREATE TABLE...:组合索引即是在多个列上创建索引。...查询时,只有在查询条件中使用了这些字段(创建组合索引的时候指定的哪些列)的最左边字段时,索引才会被使用。...:MySQL只有MyISAM存储引擎支持FULLTEXT索引,并且类类型为CHAR、TEXT、VARCHAR。
B站搜索“乐哥聊编程“有本篇文章配套视频 https://www.bilibili.com/video/BV1je4y117yP 非聚集索引(MyISAM) 索引和数据单独存放 表有三个文件 叶子结点存放行数据地址信息...通过查找到主键key,然后还得根据指针地址去数据表中找对应的数据行 聚集索引(InnoDB) 索引和数据存放在一起 创建表之后会产生两个文件 叶子结点存放行数据 留几个关于InnoDB 常见的几个面试题...为什么Innodb非主键索引叶子节点存储的是主键值,而不是数据本身?
POLICYIMPART_INDEX ON ROOTE.W_POLICYIMPART( POLICYID ASC, IMPARTCODE ASC, CUSTOMERTYPE ASC )POLICYIMPART_INDEX索引名称
联合索引 概念 联合索引又叫复合索引,即一个覆盖表中两列或者以上的索引,例如: index_name(column a,column b) 1 创建方式 执行alter table语句时创建 alter...;table_name是要创建该索引的表名;column_list为该索引所包含的表的字段名。...执行create index语句时创建 create index index_name on table_name(column_list) 1 此种情况是在表已经创建好的情况下,再来创建复合索引。...如果我们是在name和age上分别创建单个索引的话,由于mysql查询每次只能使用一个索引,所以虽然这样已经相对不做索引时全表扫描提高了很多效率,但是如果在name、age两列上创建复合索引的话将带来更高的效率...如果我们创建了(name, age)的复合索引,那么其实相当于创建了(name)、(name,age)两个索引,这被称为最佳左前缀特性。
1、索引需要占用磁盘空间,因此在创建索引时要考虑到磁盘空间是否足够 2、创建索引时需要对表加锁,因此实际操作中需要在业务空闲期间进行 SELECT * FROM table_name WHERE...在已存在的表中,可以使用ALTER TABLE语句或者CREATE INDEX语句创建索引 在已存在的表中,索引的创建语句结构 1.普通索引(Normal): ALTER TABLE 表名 ADD INDEX...大家可以尝试自己添加一下 删除索引语句结构 删除索引的语句方式主要有以下两种 删除主键索引 alter table 表名 drop primary; 其他索引的删除 ALTER TABLE 表名 DROP...查看表中的索引 show keys from 表名; show index from 表名; desc 表名; 查看查询语句使用索引的情况 //explain 加查询语句 explain SELECT...,因此会占用存储空间,一般来说,索引表占用的空间的数据表的1.5倍;索引表的维护和创建需要时间成本,这个成本随着数据量增大而增大;构建索引会降低数据表的修改操作(删除,添加,修改)的效率,因为在修改数据表的同时还需要修改索引表
非聚集索引和聚集索引一样都是B-树结构,但是非聚集索引不改变数据的存储方式,所以一个表允许建多个非聚集索引;非聚集索引的叶层是由索引页而不是由数据页组成,索引行包含索引键值和指向表数据存储位置的行定位器...非聚集索引 Index_id>1 可以结合语句查询 SELECT o.name AS table_name,p.index_id, i.name AS index_name , au.type_desc...非聚集索引列的选择 同样非聚集索引避免选择宽列,这点与聚集索引一样。...当索引包含查询中的所有列时,性能可以提升。查询优化器可以找到索引内的所有列值;不会访问表或聚集索引数据,这样就减少了磁盘 I/O 操作。使用具有包含列的索引来添加覆盖列,而不是创建宽索引键。...INSERT、UPDATE、DELETE 和 MERGE 语句的性能,因为当表中的数据更改时,所有索引都须进行适当的调整 总结 这篇文章更重要的是讲述索引的存储结构和查找方式,没有讲述索引的一些基本概念和语句的写法
聚集索引和非聚集索引 在 MySQL 数据库中 InnoDB 存储引擎,B+ 树可分为聚集索引和非聚集索引。聚集索引也叫聚簇索引,非聚集索引也叫辅助索引或者二级索引。...在创建表添加的索引都是非聚集索引,非聚集索引就是一个为了找到聚集索引的二级索引,通过二级索引索引找到主键,再查找数据。创建一个表 T,表中有个一个主键id。...当创建表和插入数据后会生成两棵树: 其中左边的是聚集索引,右边的是非聚集索引。非聚集索引叶子节点存储的是主键的值,聚集索引存储的是整行的数据。...索引下推(icp) 索引下推是 mysql 5.6 新特性 创建一个表 use,其中主要有几个字段:id、name、age、address。建立联合索引(name,age)。...这条语句在 Mysql 5.6 之前和 Mysql 5.6 以及 Mysql 5.6 以后版本执行是不一致的。
1.添加PRIMARY KEY(主键索引) mysql>ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) 例:alter table yx_marketing_details...add index(id); 2.添加UNIQUE(唯一索引) mysql>ALTER TABLE `table_name` ADD UNIQUE (`column` ) 3.添加INDEX...(普通索引) mysql>ALTER TABLE `table_name` ADD INDEX index_name ( `column` ) 4.添加FULLTEXT(全文索引) mysql...>ALTER TABLE `table_name` ADD FULLTEXT ( `column`) 5.添加多列索引 mysql>ALTER TABLE `table_name` ADD INDEX