Maison > base de données > tutoriel mysql > le corps du texte

mysql判断索引存在时删除索引的方法_MySQL

WBOY
Libérer: 2016-06-01 13:36:04
original
3297 Les gens l'ont consulté

bitsCN.com

mysql判断索引存在时删除索引的方法

 

mysql的drop index语句不支持if exists条件,在sql中先删除索引,

再创建索引,如果对于新建的数据库,库中没有该索引,就会报错,

导致后面的sql不再执行。

因此需要使用存储过程来判断索引是否存在,如果存在则删除。

sql代码如下:

 

Sql代码  

DROP PROCEDURE IF EXISTS del_idx;  

create procedure del_idx(IN p_tablename varchar(200), IN p_idxname VARCHAR(200))  

begin  

DECLARE str VARCHAR(250);  

  set @str=concat(' drop index ',p_idxname,' on ',p_tablename);   

    

  select count(*) into @cnt from information_schema.statistics where table_name=p_tablename and index_name=p_idxname ;  

  if @cnt >0 then   

    PREPARE stmt FROM @str;  

    EXECUTE stmt ;  

  end if;  

  

end ;  

call del_idx('table_name','index_name');  

ALTER TABLE table_name ADD INDEX index_name (column1, column2);

 

bitsCN.com
Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal