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

MySQL索引类型

转载自http://www.cnblogs.com/luyucheng/p/6289714.html 一、简介 MySQL目前主要有以下几种索引类型: 1.普通索引 2.唯一索引 3.主键索引...,表示索引的长度,只有字符串类型的字段才能指定索引长度 6.asc或desc指定升序或降序的索引值存储 三、索引类型 1.普通索引 是最基本的索引,它没有任何限制。...(4)删除索引 DROP INDEX index_name ON table 2.唯一索引 与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。...因为更新表时,不仅要保存数据,还要保存一下索引文件。 2.建立索引会占用磁盘空间的索引文件。一般情况这个问题不太严重,但如果你在一个大表上创建了多种组合索引索引文件的会增长很快。...短索引不仅可以提高查询速度而且可以节省磁盘空间和I/O操作。 3.索引列排序 查询只使用一个索引,因此如果where子句中已经使用了索引的话,那么order by中的列是不会使用索引的。

66610

MySQL索引类型

1.索引类型 1.1 普通索引 NORMAL: 是最基本的索引,它没有任何限制。 1.2 唯一索引 SPATIAL: 与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。...如果是组合索引,则列值的组合必须唯一。 1.3 主键索引: 是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值。...一般是在建表的时候同时创建主键索引: 1.4 组合索引: 指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。...使用组合索引时遵循最左前缀集合 1.5 全文索引 主要用来查找文本中的关键字,而不是直接与索引中的值相比较。...2.2 建立索引会占用磁盘空间的索引文件。一般情况这个问题不太严重,但如果你在一个大表上创建了多种组合索引索引文件的会增长很快。

1.4K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    MySql索引类型

    Mysql支持哪几种索引 索引是在MySql的存储引擎层中实现的,而不是在服务器层 从数据结构角度 1、B+树索引(O(log(n))):关于B+树索引,可以参考 MySQL索引背后的数据结构及算法原理...,则MySQL自动为InnoDB表生成一个隐含字段作为主键,这个字段长度为6个字节,类型为长整形。...,MYSQL中的空间数据类型有4种,分别是GEOMETRY、POINT、LINESTRING、POLYGON。...MYSQL使用SPATIAL关键字进行扩展,使得能够用于创建正规索引类型的语法创建空间索引。...,为可选参数,如果不指定,MYSQL默认col_name为索引值; 5、length为可选参数,表示索引的长度,只有字符串类型的字段才能指定索引长度; 6、asc或desc指定升序或降序的索引值存储 缺点

    1.6K10

    mysql索引类型索引方式

    1.什么是索引MySQL中,索引(index)也叫做“键(key)”,它是存储引擎用于快速找到记录的一种数据结构。...2.索引的分类 在MySQL中,通常我们所指的索引类型,有以下几种: 主键索引(PRIMARY KEY) 也简称主键。它可以提高查询效率,并提供唯一性约束。一张表中只能有一个主键。...一般把主键定义在无意义的字段上(如:编号),主键的数据类型最好是数值。...ADD PRIMARY KEY (`name`) USING BTREE; 全文索引(FULL TEXT) 旧版的MySQL的全文索引只能用在MyISAM表格的char、varchar和text的字段上...不过新版的MySQL5.6.24上InnoDB引擎也加入了全文索引 添加全文索引 ADD FULLTEXT INDEX `idx_full`(`en_name`); 跟普通索引稍有不同 使用全文索引的格式

    1K30

    MySQL索引类型

    一、索引的分类 1、唯一索引和普通索引 普通索引:是MySQL中的基本索引类型,允许在定义索引的列中插入重复值和空值。 唯一索引索引列的值必须唯一,但允许有空值。...使用组合索引时遵循最左前缀集合。 3、全文索引( fulltext) 全文索引类型为FULLTEXT,在定义索引的列上支持值得全文查找,允许在这些索引列 中插入重复值和空值。...全文索引可以在CHAR、VARCHAR或者TEXT类型的列上创建。MySQL 5.7.xx之前只有MyISAM存储引擎支持全文索引。...4、空间索引 空间索引是对空间数据类型的字段建立的索引MySQL中的空间数据类型有4中,分别是: geometry、point、linstring和polygon 。...6、空间索引 空间索引:必须在MyISAM类型的表中创建,且空间类型的字段必须为非空。

    1.3K30

    MySQL 索引类型

    索引有很多种类型,为不同的场景提供更好的性能。在MySQL中,索引是在存储引擎层而不是服务器层实现。不同存储引擎的索引其工作方式并不一样。也不是所有存储引擎都支持所有类型索引。...大多数 MySQL 引擎都支持这种索引。之所以称之为“B-Tree” 是因为 MySQL 在创建表和其他语句中也使用该关键字。...叶子节点比较特别,它们的指针指向的是被索引的数据,而不是其他的节点页(不同引擎的“指针”类型不同)。...四、全文索引 ---- 全文索引是一种特殊类型索引,他查找的是文本中的关键词,而不是直接比较索引中的值。全文搜索和其他几类索引的匹配方式完全不一样。...五、其他索引类型 ---- 还有第三方的存储引擎使用不同类型的数据结构来存储索引

    1.4K30

    MySQL常见索引类型

    关系型数据库中的索引,能够提升数据检索的效率,是提升性能的主要途径,GreatSQL开源社区推送的这篇《MySQL 常见索引类型介绍》,介绍了在MySQL中常见的几种索引。...MySQL 主要索引类型有如下几种, (1) 主键索引。 (2) 唯一索引。 (3) 普通索引。 (4) 空间索引。 (5) 全文索引。...`idx_u1` (`u1`) 单列索引,即索引创建在单个列上, # 创建单列索引 mysql> alter table t1 add index idx_u1(`u1`); # 查看创建的索引关键词..., 空间索引是对空间数据类型的字段建立的索引MYSQL使用SPATIAL关键字进行扩展,使其能够在空间数据类型的语法上创建空间索引。...的TIMESTAMP数据类型》 《你知道雨的类型有几种?》

    86740

    mysql索引类型有哪些

    mysql索引类型有:最基本的没有限制的普通索引索引列的值必须唯一的唯一索引,主键索引,多个字段上创建的组合索引以及用来查找文本中的关键字的全文索引 微信图片_20191202154142.jpg...MySQL中的索引类型有以下几种 普通索引 唯一索引 主键索引 组合索引 全文索引 1、普通索引 是最基本的索引,它没有任何限制。...一般是在建表的时候同时创建主键索引: 微信图片_20191202154733.png 4、组合索引 指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。...因为更新表时,不仅要保存数据,还要保存一下索引文件。 2、建立索引会占用磁盘空间的索引文件。一般情况这个问题不太严重,但如果你在一个大表上创建了多种组合索引索引文件的会增长很快。...5、不要在列上进行运算,这将导致索引失效而进行全表扫描,例如 微信图片_20191202161035.png 6、不使用not in和操作 以上就是mysql索引类型有哪些的详细内容

    4.3K31

    MySQL 常见索引类型介绍

    MySQL 主要索引类型有如下几种: 1.主键索引 2.唯一索引 3.普通索引 4.空间索引 5.全文索引 假设有如下一张表 CREATE TABLE `t1` ( `id` bigint unsigned...如果是组合索引,则列值的组合必须唯一 # 创建唯一索引 mysql> alter table t1 add unique idx_u1(`u1`); # 查看创建的索引关键词 UNIQUE KEY `...idx_u1` (`u1`) 单列索引索引创建在单个列上 # 创建单列索引 mysql> alter table t1 add index idx_u1(`u1`); # 查看创建的索引关键词 KEY...`idx_u1` (`u1`) 多列索引 创建多列索引时记得遵循最左匹配原则,把区分度较高的字段放前面 # 创建多列索引 mysql> alter table t1 add index idx_u1_...空间索引是对空间数据类型的字段建立的索引MYSQL使用SPATIAL关键字进行扩展,使其能够在空间数据类型的语法上创建空间索引

    70930

    ​打工人必备:详解MySQL索引类型索引优点

    如果索引包含多个列,那么列的顺序也十分重要,因为mysql只能高效的使用索引的最左前缀列。创建一个包含列个列的索引,和创建两个只包含一列的索引是大不相同的。...在mysql中,索引是存储引擎层而不是服务器层实现的。不同的存储引擎的索引的工作方式并不一样,也不是所有的存储引擎都支持所有类型索引。即使多个存储引擎支持同一种类型索引,其底层的实现也不能不同。...一、索引类型 1、B-Tree索引 大多数mysql存储引擎都支持B-Tree索引。存储引擎以不同的方式使用B-Tree索引,性能也各不相同。...哈希索引将所有的哈希码存储在索引中,同时在哈希表中保存指向每个数据行的指针。 在mysql中,只有memory引擎显示的支持哈希索引。...必须使用mysql的GIS相关函数来维护数据。 4、全文索引 全文索引是一种特殊类型索引,他查找的是文本中的关键词,而不是直接比较索引中的值。全文搜索和其他几类索引的匹配方式完全不一样。

    1K10

    【说站】mysql有哪些索引类型

    mysql有哪些索引类型 索引类型 1、主键索引字段值不能是null,也不能重复。 只能作用于一个字段(列)。 2、唯一索引字段值可以是null,但不能重复。 只能作用于一个字段。...3、普通索引可以作用于一个或多个字段,对字段值没有限制。 在为一个字段建立索引时,称为单值索引,在多个字段同时建立索引时,称为复合索引(提取多个字段值组合)。...实例 mysql> create table `student` (     -> `id` int(10) not null auto_increment,     -> `stuId` int(32...> insert into student(stuId,name) values(null,'tom'); Query OK, 1 row affected (0.11 sec) 以上就是mysql索引类型的介绍...更多mysql学习指路:MySQL 推荐操作系统:windows7系统、mysql5.8、DELL G3电脑

    1.8K30

    数据库MySQL-索引类型

    1.索引类型 1.1 普通索引 NORMAL: 是最基本的索引,它没有任何限制。 1.2 唯一索引 SPATIAL: 与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。...如果是组合索引,则列值的组合必须唯一。 1.3 主键索引: 是一种特殊的唯一索引,一个表只能有一个主键,不允许有空值。...一般是在建表的时候同时创建主键索引: 1.4 组合索引: 指多个字段上创建的索引,只有在查询条件中使用了创建索引时的第一个字段,索引才会被使用。...使用组合索引时遵循最左前缀集合 1.5 全文索引 主要用来查找文本中的关键字,而不是直接与索引中的值相比较。...2.2 建立索引会占用磁盘空间的索引文件。一般情况这个问题不太严重,但如果你在一个大表上创建了多种组合索引索引文件的会增长很快。

    1.7K30

    mysql索引类型和优缺点

    在JOIN操作中(需要从多个数据表提取数据时),MySQL只有在主键和外键的数据类型相同时才能使用索引。...只要有可能,就应该选择一个数据最整齐、最紧凑的数据列(如一个整数类型的数据列)来创建索引。 2. 唯一索引 普通索引允许被索引的数据列包含重复的值。...索引的长度 在为CHAR和VARCHAR类型的数据列定义索引时,可以把索引的长度限制为一个给定的字符个数(这个数字必须小于这个字段所允许的最大字符个数)。...在为BLOB和TEXT类型的数据列创建索引时,必须对索引的长度做出限制;MySQL所允许的最大索引长度是255个字符。...在生成这种类型索引时,MySQL将把在文本中出现的所有单词创建为一份清单,查询操作将根据这份清单去检索有关的数据记录。

    2.4K70

    mysql索引类型 normal, unique, full text

    问题1:mysql索引类型normal,unique,full text的区别是什么?...二、根据sql查询语句确定创建哪种类型索引,如何优化查询   选择索引列:   a.性能优化过程中,选择在哪个列上创建索引是最重要的步骤之一。...可以考虑使用索引的主要有   两种类型的列:在where子句中出现的列,在join子句中出现的列。   b.考虑列中值的分布,索引的列的基数越大,索引的效果越好。   ...mysql 索引分类 在数据库表中,对字段建立索引可以大大提高查询速度。通过善用这些索引,可以令 MySQL的查询和运行更加高效。索引是快速搜索的关键。...MySQL索引的建立对于MySQL的高效运行是很重要的。下面介绍几种常见的MySQL索引类型。 1、普通型索引 这是最基本的索引类型,而且它没有唯一性之类的限制。

    2.3K20

    mysql 索引类型以及使用场景

    关于MySQL索引的好处,如果正确合理设计并且使用索引MySQL是一辆兰博基尼的话,那么没有设计和使用索引MySQL就是一个人力三轮车。...普通索引 这是最基本的索引,它没有任何限制,比如上文中为title字段创建的索引就是一个普通索引,MyIASM中默认的BTREE类型索引,也是我们大多数情况下用到的索引。...全文索引(FULLTEXT) MySQL从3.23.23版开始支持全文索引和全文检索,在mysql5.6版本以前FULLTEXT索引仅可用于 MyISAM 表,在5.6之后innodb引擎也支持...索引只是提高效率的一个因素,如果你的MySQL有大数据量的表,就需要花时间研究建立最优秀的索引,或优化查询语句。下面是一些总结以及收藏的MySQL索引的注意事项和优化方法。 1....而理论上每张表里面最多可创建16个索引,不过除非是数据量真的很多,否则过多的使用索引也不是那么好玩的,比如我刚才针对text类型的字段创建索引的时候,系统差点就卡死了。

    1.6K10

    扫码

    添加站长 进交流群

    领取专属 10元无门槛券

    手把手带您无忧上云

    扫码加入开发者社群

    相关资讯

    热门标签

    活动推荐

      运营活动

      活动名称
      广告关闭
      领券