mysql联表索引怎么走 mysql联合索引

mysql联合索引如何创建?

CREATE TABLE `test` ('aaa' varchar(16) NOT NULL default '', 'bbb' varchar(16) NOT NULL default '', 'ccc' int(11) UNSIGNED NOT NULL default 0, KEY `sindex` (`aaa`,`bbb`,`ccc`) ) ENGINE=MyISAM COMMENT='';\x0d\x0a\x0d\x0a这样就在 aaa、bbb、ccc 3列上建立联合索引了。\x0d\x0a\x0d\x0a如果表已经建好了,那么就在phpmyadmin里面执行:\x0d\x0aalert table test add INDEX `sindex` (`aaa`,`bbb`,`ccc`) \x0d\x0a\x0d\x0a就可以在这3列上建立联合索引了。

公司主营业务:成都网站设计、做网站、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联建站是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联建站推出花垣免费做网站回馈大家。

MySQL联表查询的索引使用

一共3张表 knowledge , knowledge_question , knowledge_answer ,数据在 6000~10000 之间。

执行的语句:

执行时间约 10分钟 ,查看执行计划如下:

全部都是全表扫描,根据MySQL联表查询的算法 Nested-Loop Join ,MySQL查询的结果集是3张表的笛卡尔积,所以效率特别低。

耗时变成 20毫秒

给Where条件建立索引,并不一定会使用。

比如:在表 knowledge 的字段 update 上建立索引 idx_time :

结果执行上来看,并没有使用索引 idx_time 。

如果where条件从 k.update_time'2019-01-03 12:00:00' 修改为 k.update_time='2019-01-03 12:00:00' (从 变成 = )

则会使用索引 idx_time

在建立索引的时候,会遇到 Table Metadata Lock 的问题,可以先 show processlist ,找到占用表锁的连接,然后 kill 。

mysqlunionall无法走索引

mysqlunionall无法走索引11 27

1. like %%失效。 方案:改为like %,只写后面的%就能走索引。

2. 虽然有索引,但是查询条件没有索引列或者order by 排序没有索引列。 方案:让查询条件有索引列

3. 索引列存在null值的情况。 方案:索引列如果没有值,则给空字符串或者数字的0,总之就是不要设置null

当前名称:mysql联表索引怎么走 mysql联合索引
文章来源:https://www.cdcxhl.com/article42/doghchc.html

成都网站建设公司_创新互联,为您提供网页设计公司网站维护定制开发网站策划营销型网站建设网站内链

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

网站优化排名