MySQL判断索引存在并删除索引的存储过程

MySQL没有直接类似建表语句常用的create xxx if exists yyy这样的语句来判断索引是否存在。
如果需要单独建索引,重复索引会导致脚本出错(Duplicate key)。
此时可以用存储过程来解决,看代码便知:

SELECT 'create procedure sp_dropindex' AS prompt;
DROP PROCEDURE IF EXISTS sp_dropindex;
DELIMITER //
CREATE PROCEDURE sp_dropindex
(
   IN    databasename             VARCHAR(50)   , 
   IN    tablename                VARCHAR(50)   , 
   IN    indexname                VARCHAR(50)
)
proc:BEGIN    
    DECLARE   str       VARCHAR(512)  DEFAULT NULL;
    DECLARE   cnt       INT           DEFAULT 0;
    SET @str = CONCAT(' drop index ',indexname,' on ',databasename,'.',tablename);

    SELECT COUNT(*) INTO cnt FROM information_schema.statistics 
        WHERE TABLE_SCHEMA=databasename AND TABLE_NAME=tablename
        AND INDEX_NAME=indexname;

    IF cnt > 0 THEN
    PREPARE stmt FROM @str;
    EXECUTE stmt;
    END IF;
    LEAVE proc;
END
//
DELIMITER ;

示例:比如要创建一个索引,为了防止重复索引而导致创建失败,可以先删除索引再创建索引,确保脚本不出错:

CALL sp_dropindex('crawler','t_user','username_idx');
CREATE INDEX username_idx ON t_user(username);

其中,crawler是数据库名称,t_user是表名称,username_idx是索引名称。

你可能感兴趣的:(笔记,mysql)