我是MySQL的新手,我有一个存储过程,我想添加到几个旧数据库。我正在使用SQLyog,我想遍历连接上的每个数据库,如果它匹配'application_%'(数据库被称为application_clientName
,则有几十个)来运行存储过程。
我可以保存并运行SQLyog的脚本是理想的。
我有点想要遍历SHOW DATABASES中的所有数据库并运行一个语句,如果它们的名字是LIKE'application_%'。该语句将在该数据库中创建一个通用存储过程。
答案 0 :(得分:4)
好的,看起来information_scheme
数据库中的SCHEMATA表包含所有数据库的列表。因此,为了获得要运行该过程的所有数据库的列表,您可以执行以下操作:
SELECT schema_name FROM information_schema.schemata
WHERE schema_name LIKE 'application_%';
下一步是将其用于某种程序。不幸的是,如果涉及创建过程,MySQL不能很好地执行动态生成的SQL。因此,我提出的纯SQL版本有点乱。它归结为首先创建“生成器”过程,然后调用它,最后执行生成器的结果:
delimiter //
DROP PROCEDURE IF EXISTS create_procedures//
CREATE PROCEDURE create_procedures()
BEGIN
DECLARE done INT DEFAULT 0;
DECLARE db VARCHAR(255);
DECLARE appDBs CURSOR FOR SELECT schema_name FROM information_schema.schemata WHERE schema_name LIKE 'application_%';
DECLARE CONTINUE HANDLER FOR NOT FOUND SET done = 1;
SET @procName = "simpleproc"; -- Change this to your proc name
SET @output = "delimiter //";
OPEN appDBs;
REPEAT
FETCH appDBs INTO db;
IF NOT done THEN
-- Replace this procedure declaration with your procedure.
-- Make sure to keep the ',db,' syntax there.
-- You should really only have to change the parameters
-- and the stuff between the BEGIN and END clauses.
SET @output = CONCAT(@output,'
DROP PROCEDURE IF EXISTS ',db,'.',@procName,'//
CREATE PROCEDURE ',db,'.',@procName,'()
BEGIN
SELECT 1;
END//');
END IF;
UNTIL done END REPEAT;
CLOSE appDBs;
SET @output = CONCAT(@output,'\ndelimiter ;');
SELECT @output AS procs;
END//
delimiter ;
生成此过程后,请调用以下过程:
CALL create_procedures();
这将输出一个包含为所有application_%
表创建过程所必需的SQL的列。选择整个列(它将相当长),并将其作为新的SQL查询执行。
我从未使用过SQLyog,但是如果它不能正常工作,那么你可能需要使用MySQL的命令行界面。首先,生成包含以下内容的文件input.sql
CALL create_procedures();
然后执行以下命令:
mysql -u <username> -p --database=<dbname> -N -r -B < input.sql > proc.sql
mysql -u <username> -p --database=<dbname> < proc.sql
将<username>
和<dbname>
更改为适当的值(<dbname>
可以是您有权访问的任何数据库)。如果您没有遇到任何错误,那么您应该为每个数据库定义存储过程。