MySQL判断索引存在并删除索引的存储过程
16lz
2021-01-22
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是索引名称。
更多相关文章
- 0926MySQL中ICP索引下推
- mysql 操作索引FORCE INDEX
- InnoDB辅助索引页面的物理结构是什么样子的
- MySQL索引的基础初识
- 为获得快速结果,我的查询有什么好的索引?
- Mysql存储过程、索引
- mysql联合索引分析测试
- MySQL索引帮助-哪个更快?
- 高性能Mysql——创建高性能的索引