mysqlインデックスが存在すると判断したときにインデックスを削除する方法


詳細
mysqlのdrop index文はif exists条件をサポートしていません.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);