只能一个个删除:
alter
table
表名
drop
index
索引名;
所以不想每次只删除一个所以然后再重建一次索引,我想一次性删除那些多余的索引,这样索引只需要重建一次
----------------------
你这话有问题.说明你对其机制理解有误.
mysql下不同存储引擎索引的组织方式有点不同的
如果你是myisam,可以一个个直接删除
如果你是innodb的,则应先删除非主键索引,到最后才删除主键索引
mysql中如何查看和删除唯一索引.
查看唯一索引:
show
from
mytable;//mytable
是表名
查询结果如下:
查询到唯一索引后,如何删除唯一索引呢,使用如下命令:
mytable
mdl_tag_use_ix;//mdl_tag_use_ix是上表查出的索引名,key_name
删除主键时是否会删除索引? 答案取决于索引是创建主键时自动创建的,还是创建主键前手工创建的.
测试如下:--建表create table hqy_test(id integer) ;--建索引create (unique)index idx_hqy_id on hqy_test(id) ;--加主键alter table hqy_test add constraint pk_hqy_id primary key (id);
select index_name from user_indexes where index_name='IDX_HQY_ID';IDX_HQY_ID
---删除主键
alter table hqy_test drop constraint pk_hqy_id;或者:alter table hqy_test drop primary key; 也是行的.
select index_name from user_indexes where index_name='IDX_HQY_ID';
IDX_HQY_ID ==没有删除索引
--删除索引,增加主键并自动创建索引
drop index idx_hqy_id;
alter talbe hqy_test add constraint pk_hqy_id primary key(id) using index;
select index_name from user_indexes where index_name='PK_HQY_ID';
PK_HQY_ID ==自动创建了索引
--删除主键约束
alter table hqy_test drop primary key;
无 ==索引被删除了
如果删除主键时,希望同时删掉索引,则应该增加drop index选项,从而不管索引是否是创建主键时自动创建的,即:alter table hqy_test drop primary key drop index;
删除索引可以使用ALTER TABLE或DROP INDEX语句来实现,DROP INDEX可以在ALTER TABLE内部作为一条语句处理,其格式如下:
DROP INDEX index_name?ON?talbe_name
ALTER TABLE table_name DROP INDEX index_name
ALTER TABLE table_name DROP PRIMARY KEY
注:其中,前两条语句是等价的,删除掉table_name中的索引index_name.
扩展资料:
索引的使用及注意事项?
EXPLAIN可以帮助开发人员分析SQL问题,explain显示了mysql如何使用索引来处理select语句以及连接表,可以帮助选择更好的索引和写出更优化的查询语句.
使用方法,在select语句前加上Explain就可以了:Explain select * from user where id=1;
尽量避免这些不走索引的sql:
SELECT * FROM ◆houdunwang◆ WHERE ◆uname◆ LIKE'后盾%' 走索引
SELECT * FROM ◆houdunwang◆ WHERE ◆uname◆ LIKE "%后盾%" 不走索引
正则表达式不使用索引,这应该很好理解,所以为什么在SQL中很难看到regexp关键字的原因.
字符串与数字比较不使用索引;
CREATE TABLE ◆a◆ (◆a◆ char(10));
EXPLAIN SELECT * FROM ◆a◆ WHERE ◆a◆="1" 走索引
EXPLAIN SELECT * FROM ◆a◆ WHERE ◆a◆=1 不走索引
以上就是土嘎嘎小编为大家整理的mysql怎么删除其中一个索引相关主题介绍,如果您觉得小编更新的文章只要能对粉丝们有用,就是我们最大的鼓励和动力,不要忘记讲本站分享给您身边的朋友哦!!