600字范文,内容丰富有趣,生活中的好帮手!
600字范文 > mysql判断是否存在索引并删除_mysql判断索引存在时删除索引的方法

mysql判断是否存在索引并删除_mysql判断索引存在时删除索引的方法

时间:2023-12-22 02:06:32

相关推荐

mysql判断是否存在索引并删除_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);

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。