本文摘自PHP中文网,作者黄舟,侵删。
着重基础之―MySql 不能遗忘的索引操作
关于MySql索引的基础知识我就不在这里写了,我不太想当信息的搬运工。
技巧分享:Workbench 作为一款专为MySQL设计的ER/数据库建模工具。除了管理数据库外,其实也是一款Sql语句生成利器。合理利用,将带来事半功倍的效果。当然,前提是我们对基础知识的了解。
我先来整理一些索引操作的Sql语句,之所以整理,起因是我遇到问题时,在百度里查到的回复,基本上都是错的,需要有人来纠正。
1.多主键(PRIMARY)删除
假设场景:你在表里定义了多个主键(PRIMARY),比如:id是自增主键,userCode也定义成了主键、userAge也定义成了主键。你打算只保留一个id,其他俩个删除,那么对应的Sql语句如下:
解释:对指定表进行修改,删除 PRIMARY KEY,同时增加 id 做为 PRIMARY KEY。
1 2 |
|
2.增加普通索引
警告:千万别不改就执行,table_name不是我强调的重点,我要说的是index_name,一定要合理规范索引的命名,例如index_字段名称,或者你有更好的,可以给我留言。
否这你会报错: Duplicate key error in MySQL (Duplicate key name '')。可以肯定的是因为 index_name 没改。沿用了index_name。
1 |
|
3.关于索引使用规范
(1).索引的使用
索引是需要占用物理存储空间的,索引的使用不当,不但会占用存储空间,而且对查询速度还会起到适得其反的作用,所以索引的定义要数据库设计是要有很清晰的认识。建索引的几大原则
1 2 3 4 5 6 7 8 9 |
|
(2).索引类型
1.普通索引
最基本的索引,没有任何限制
2.唯一索引
索引列的值必须唯一,但允许有空值
3.主键索引
主键索引属于一种特殊的唯一索引,不允许有空值
4.单列索引
单个多列索引(组合索引)效率高于多个单列索引
5.最左前缀(Leftmost Prefixing):多列索引
以上就是MySql中非常重要的索引操作的详细内容,更多文章请关注木庄网络博客!!
相关阅读 >>
mysql数据库报错:too many connections的解决办法
更多相关阅读请进入《mysql》频道 >>

数据库系统概念 第6版
本书主要讲述了数据模型、基于对象的数据库和XML、数据存储和查询、事务管理、体系结构等方面的内容。