mysql 不同 索引,MySQL索引,不同类型以及何时使用它们?

好的,所以我(重新)搜索了很多有关MySQL索引及其重要性的内容,我知道我必须使用它来使数据库查询运行得更快.

我知道在任何字段上添加索引的语法.

但这是我不明白的,(我正在使用Heidi SQL在本地管理数据库)

我有一个包含以下字段的表

id

company_id

author_id

client_id

project_id

title

description

status

date

这里,id是主键,自动递增并已经编入索引.

我想在company_id,author_id,client_id,project_id上添加一个索引,但我这里有几个不同的选项(Heidi SQL:选择字段,右键单击,创建新索引)Key,Unique,Full Text,Spatial

我知道(猜测)Key只会为该字段编制索引,Unique将确保该字段必须是唯一的,如果我计划在该字段上执行搜索,则全文索引将是最佳的.

问题1:Spatial做什么,我应该在何时何地使用此索引.

问题2:在创建和索引时,我有2个选项,可以创建新索引或添加到已存在的索引(如主要字段的名称).

创建新索引或添加到现有索引之间的区别是什么?为每个不同的字段创建一个不同名称的索引我索引一个好主意,或者我应该创建/添加相同名称下的所有索引.

谢谢你的时间.

解决方法:

您应该从一个简单的Key索引开始.如果添加可能会产生意外后果的Unique,例如在像company_id这样的列上强制执行唯一性肯定不会起作用(许多行将共享同一个company_id).

空间索引仅用于地理编码数据(纬度/经度值),因此这不适用于任何这些数据.如果要按字段内的单词搜索,则使用全文索引,它也不会应用于您拥有的数值.此外,全文索引仅在MyISAM中可用,而不是INNODB事务引擎,因此如果您想要迁移表,这将是一个障碍.

如果添加到现有索引,则会在多个列上创建“复合”索引.通常,这不是一个好主意,除非您尝试在不是唯一的列的索引中强制实施唯一性.例如,您可以索引:company_id id,并在这种情况下使其唯一.但是,索引占用的空间更多,写入速度也会更慢.

总之,您应该只对要搜索的列使用普通的KEY索引. MySQL将只为每个查询使用一个索引,以查看它实际访问可以使用EXPLAIN实用程序的数据的方式.您希望确保以有效的方式使用索引来缩小需要返回的行数或搜索最佳性能.

标签:mysql,database,indexing,relational-database,heidisql

来源: https://codeday.me/bug/20190624/1278769.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值