mysql判斷索引存在時刪除索引的方法
mysql的drop index語句不支持if exists條件,在sql中先刪除索引,
再創(chuàng)建索引,如果對于新建的數(shù)據(jù)庫,庫中沒有該索引,就會報(bào)錯,
導(dǎo)致后面的sql不再執(zhí)行。
因此需要使用存儲過程來判斷索引是否存在,如果存在則刪除。
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聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時與本網(wǎng)聯(lián)系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com