mysql 创建索引后怎么根据索引去查询

mysql 创建索引后怎么根据索引去查询,第1张

mysql 添加索引后 在查询的时候是mysql就自动从索引里面查询了。如果需要也可以单独根据索引查询,这个看使用场景

MYSQL在创建索引后对索引的使用方式分为两种:

1 由数据库的查询优化器自动判断是否使用索引;

2 用户可在写SQL语句时强制使用索引

mysql中如何查看和删除唯一索引。

查看唯一索引:

show

index

from

mytable//mytable

是表名

查询结果如下:

查询到唯一索引后,如何删除唯一索引呢,使用如下命令:

alter

table

mytable

drop

index

mdl_tag_use_ix//mdl_tag_use_ix是上表查出的索引名,key_name

先正面回答你的问题

数据是否重复不是建立索引的重要依据,甚至都不是依据。

只要不完全重复(所有元组的该元素都一样),那么建立索引就是有意义的。

即使当前数据完全重复,也不是不能建立索引,这种情况有点复杂,不细说了。

对于你后面的疑问,可以给你一个如何建立索引的忠告,“如何查就如何建”。

索引的建立,唯一的原因就是为了查询(广义的查询),实际上建立索引会使得数据存储所占空间变大,有时索引所占的空间会查过数据本身的空间。索引的建立也会使得数据插入时变慢,特殊情况下,慢的难以忍受,所以dba的重要工作之一,就是检查索引层级并优化。

索引建立的唯一好处,就是按照索引查询时,变快了。type,status这2个字段是否适合建立索引,就要看你是否要按照这2个字段进行检索。而检索的顺序决定了如何建立索引。

对于索引类型和索引方式,我建议就

normal

btree

就适用于大多数情况。若你参与的是一个大数据处理项目,对数据存储和检索有特别要求,那么需要分析多个层面,比如数据吞吐量、数据的方差、平均差等等很多参数才考虑是否用聚集索引等(mysql好像还没聚集索引),至于是否是唯一索引,我建议不使用,即使能判定数据是唯一的也不要用,全文索引也没有必要。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/6128680.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-03-15
下一篇 2023-03-15

发表评论

登录后才能评论

评论列表(0条)

保存