知道mysql的索引吗?

1

普通索引:最基本的索引,没有任何限制  

唯一索引:与"普通索引"类似,不同的就是:索引列的值必须唯一,但允许有空值。  

主键索引:它 是一种特殊的唯一索引,不允许有空值。   

全文索引:仅可用于 MyISAM 表,针对较大的数据,生成全文索引很耗时好空间。  

组合索引:为了更多的提高mysql效率可建立组合索引,遵循”最左前缀“原则。创建复合索引时应该将最常用(频率)作限制条件的列放在最左边,依次递减。 

2

mysql可能失效的场景:

1.WHERE字句的查询条件里有不等于号(WHEREcolumn!=…),mysql将无法使用索引

2.类似地,如果WHERE字句的查询条件里使用了函数(如:WHERE DAY(column)=…),MySQL将无法使用索引

3.在JOIN操作中(需要从多个数据表提取数据时),mysql只有在主键和外键的数据类型相同时才能使用索引,否则即使建立了索引也不会使用

4.如果WHERE子句的查询条件里使用了比较操作符LIKE和REGEXP,MYSQL只有在搜索模板的第一个字符不是通配符的情况下才能使用索引。比如说,如果查询条件是LIKE 'abc%',MYSQL将使用索引;如果条件是LIKE '%abc',MYSQL将不使用索引。

5.在ORDER BY操作中,MYSQL只有在排序条件不是一个查询条件表达式的情况下才使用索引。尽管如此,在涉及多个数据表的查询里,即使有索引可用,那些索引在加快ORDER BY操作方面也没什么作用。

6.如果某个数据列里包含着许多重复的值,就算为它建立了索引也不会有很好的效果。比如说,如果某个数据列里包含了净是些诸如“0/1”或“Y/N”等值,就没有必要为它创建一个索引。

7.索引有用的情况下就太多了。基本只要建立了索引,除了上面提到的索引不会使用的情况下之外,其他情况只要是使用在WHERE条件里,ORDER BY 字段,联表字段,一般都是有效的。 建立索引要的就是有效果。 不然还用它干吗? 如果不能确定在某个字段上建立的索引是否有效果,只要实际进行测试下比较下执行时间就知道。

8.如果条件中有or(并且其中有or的条件是不带索引的),即使其中有条件带索引也不会使用(这也是为什么尽量少用or的原因)。注意:要想使用or,又想让索引生效,只能将or条件中的每个列都加上索引

9.如果列类型是字符串,那一定要在条件中将数据使用引号引用起来,否则不使用索引

10.如果mysql估计使用全表扫描要比使用索引快,则不使用索引

0?wx_fmt=png

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: MySQL索引是使用B树或哈希表实现的,而不是倒排索引。B树索引是一种平衡树,可以快速定位到索引列的值,然后找到对应的行数据。而哈希索引则是将索引列的值通过哈希函数转换为哈希码,并使用哈希表进行快速查找。倒排索引则是针对文本数据而言的,它记录了每个单词出现的位置,并以此来快速定位到包含该单词的文档。 ### 回答2: MySQL索引不是倒排索引。倒排索引是一种在查找时将文档中的词条映射到其所在的位置的索引结构。而MySQL索引则是一种按照特定字段值进行排序和组织的数据结构,用于加快数据库的查询速度。MySQL索引使用了B树(B-Tree)或者B+树(B+Tree)等数据结构来实现。 MySQL索引可以根据需要在表的一个或多个列上创建。创建索引后,数据库引擎会根据索引的排序规则来组织数据,以便快速定位和访问需要查询的数据。通过使用索引,可以大大提高数据库查询的速度,减少了全表扫描的时间消耗。 倒排索引主要用于文本搜索引擎的实现中,例如全文搜索引擎(如Lucene)。通过倒排索引,可以快速定位包含指定关键词的文档,并返回相关的搜索结果。倒排索引按照词条来组织数据,而不是按照文档或记录来组织。 总之,MySQL索引和倒排索引是两种不同的索引结构,用于不同的应用场景。MySQL索引用于加速数据库查询操作,而倒排索引用于实现文本搜索引擎。 ### 回答3: MySQL索引不是倒排索引。倒排索引(Inverted Index)是一种用于快速定位关键词的数据结构,常用于搜索引擎中。它将存储记录的值映射到出现该值的记录的位置,通过查询关键词可以快速定位到包含该关键词的记录。 而MySQL索引是一种数据结构,用于提高数据库查询的效率。MySQL使用B树(B-tree)或者哈希索引来实现索引,而不是倒排索引。B树索引索引的值映射到数据库记录的物理位置,可以进行范围查询和顺序访问。哈希索引通过将索引值计算为哈希函数的结果,并存储在哈希表中,对于等值查询有较高的效率。 MySQL索引的创建可以通过关键字如INDEX或PRIMARY KEY来定义,可以加速数据库的查找和排序操作。它可以提高查询性能,减少数据库的扫描次数和IO操作。索引可以创建在单个列上,也可以创建在多个列上,称为复合索引索引的选择和设计需要考虑到查询的频率、数据量、数据类型等因素。 总之,MySQL索引和倒排索引不同,但都是用于提高数据查询效率的数据结构。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值