MySQL-索引中有许多列?还是一一?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了MySQL-索引中有许多列?还是一一?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1433字,纯文字阅读大概需要3分钟。
内容图文
![MySQL-索引中有许多列?还是一一?](/upload/InfoBanner/zyjiaocheng/886/13d89ee1d30a4bd2b3699a40d2d0b5d6.jpg)
假设一个产品最多可以投诉五(5)次.在这种情况下,有一个包含五(5)列的表.这五列直接涉及另一个表,该表中报告索赔代码.
参见:http://img263.imageshack.us/img263/4990/01mysql.jpg
从这一刻起,我必须在两个表之间建立关系.因此,以下哪一项更适合创建索引:
a)一个一个地创建索引?
ALTER TABLE `complaint` ADD INDEX (`code_01`)
ALTER TABLE `complaint` ADD INDEX (`code_02`)
ALTER TABLE `complaint` ADD INDEX (`code_03`)
ALTER TABLE `complaint` ADD INDEX (`code_04`)
ALTER TABLE `complaint` ADD INDEX (`code_05`)
b)所有字段都在一个索引中?
ALTER TABLE `complaint` ADD INDEX (`code_01`,
`code_02`,
`code_03`,
`code_04`,
`code_05`)
我相信最好的选择是a),因为如果选择选项b)并通过访问phpMyAdmin中的“ Relation View”,它表明还有其他字段在说“未定义索引!”在code_02,code_03和code_04 code_05列中.
注意-插入和更新:
如果我使用选项b)并在记录中输入了列code_02,code_03和code_04 code_05的代码,则MySQL不建议输入的代码不存在任何错误.仅返回成功消息,该消息实际上应该是不正确的.因此,在这种情况下,我必须使用选项a),对吗?
解决方法:
当您在多个列上都有索引时,仅当您通过最左边的列进行访问时才使用该索引.
选项a将创建5个单独的索引,选项B将仅创建1个索引
如果要按任何列进行搜索或排序,则必须使用选项A
但是,如果要按索引顺序按列搜索,请使用选项B
例
SELECT ID
FROM table
WHERE code_03 = 'asd' OR code_02 = 'asds'
使用选项A
SELECT ID
FROM table
WHERE code_01 = 'asd' AND code_02 = 'asds'
使用选项B
如果可以的话,请使用选项B,因为它可以使用单个索引来搜索多个列,因此会产生更好的性能.并且索引会更小.
内容总结
以上是互联网集市为您收集整理的MySQL-索引中有许多列?还是一一?全部内容,希望文章能够帮你解决MySQL-索引中有许多列?还是一一?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。