查询某张表中哪些字段创建了索引:
select user_ind_columns.index_name,user_ind_columns.column_name,
user_ind_columns.column_position,user_indexes.uniqueness
from user_ind_columns,user_indexes
where user_ind_columns.index_name = user_indexes.index_name
and user_ind_columns.table_name = '表名';
删除索引
使用ALTER TABLE 语句删除索引
alter table 表名 drop index 索引名
使用DROP INDEX 语句删除索引
drop index 索引名 on 表名
不适合创建索引
1、较频繁的作为查询条件的字段应该创建索引.
2、唯一性太差的字段不适合单独创建索引,即使频繁作为查询条件
3、更新非常频繁的字段不适合创建索引
大多数场景下比较适合:
1、对于单键索引,尽量选择针对当前查询过滤性更好的索引;
2、在选择组合索引的时候,当前查询中过滤性最好的字段在索引字段顺序中排列越靠前越好;
3、在选择组合索引的时候,尽量选择可以能够包含当前查询的where子句中更多字段索引;
4、尽可能通过分析统计信息和调整查询的写法来达到选择合适索引的目的而减少通过使用Hint人为控制索引的选择,因为这会是后期的维护成本增加,同时增加维护所带来的潜在风险。
建议:
1、表的主键、外键必须有索引;
2、数据量超过300的表应该有索引;
3、经常与其他表进行连接的表,在连接字段上应该建立索引;
4、经常出现在Where子句中的字段,特别是大表的字段,应该建立索引;
5、索引应该建在选择性高的字段上;
6、索引应该建在小字段上,对于大的文本字段甚至超长字段,不要建索引;
7、复合索引的建立需要进行仔细分析;尽量考虑用单字段索引代替:
A、正确选择复合索引中的主列字段,一般是选择性较好的字段;
B、复合索引的几个字段是否经常同时以AND方式出现在Where子句中?单字段查询是否极少甚至没有?如果是,则可以建立复合索引;否则考虑单字段索引;
C、如果复合索引中包含的字段经常单独出现在Where子句中,则分解为多个单字段索引;
D、如果复合索引所包含的字段超过3个,那么仔细考虑其必要性,考虑减少复合的字段;
E、如果既有单字段索引,又有这几个字段上的复合索引,一般可以删除复合索引;
8、频繁进行数据操作的表,不要建立太多的索引;
9、删除无用的索引,避免对执行计划造成负面影响;
1、创建表的时候同时建立索引
语法
CREATE INDEX index_name
ON { table | view } ( column )
]
create table t1(id int not null,
name char(30) not null,
unique index UniqIdx(id)
)
2、在原有的表上建立索引
使用ALTER TABLE 语句创建索引
1.执行语句
alter table book add index BkName(bookname(30))
2.show index 查看表中索引 --- 可以看到新增了一个索引 :show index from 表
创建唯一索引: alter table 表 add index uniqidx(列)
使用CREATE TABLE 语句创建索引
创建普通索引:
create index BkNameIdx on book(bookname)
创建唯一索引:
create unique index UniqIdx on book(bookId)