mysql判斷索引存在時刪除索引的方法 mysql的drop index語句不支持if exists條件,在sql中先刪除索引, 再創建索引,如果對於新建的數據庫,庫中沒有該索引,就會報錯, 導致後面的sql不再執行。 www.2cto.com 因此需要使用存儲過程來判斷索引是否存在,如果存在則刪除。 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);