
alter
table
表名
drop
index
索引名
所以不想每次只删除一个所以然后再重建一次索引,我想一次性删除那些多余的索引,这样索引只需要重建一次
----------------------
你这话有问题.说明你对其机制理解有误.
mysql下不同存储引擎索引的组织方式有点不同的
如果你是myisam,可以一个个直接删除
如果你是innodb的,则应先删除非主键索引,到最后才删除主键索引
怎么删除MySQL索引呀,表结构如下,我删除索引报错:1、删除索引的语句:
drop index index_name
2、Code2 你是单引号 还是反向单引号,注意这个。
删除主键时是否会删除索引? 答案取决于索引是创建主键时自动创建的,还是创建主键前手工创建的。测试如下:--建表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
select index_name from user_indexes where index_name='PK_HQY_ID'
无 ==索引被删除了
如果删除主键时,希望同时删掉索引,则应该增加drop index选项,从而不管索引是否是创建主键时自动创建的,即:alter table hqy_test drop primary key drop index
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)