Mysql 在多个数据库上安装存储过程

Mysql 在多个数据库上安装存储过程,mysql,stored-procedures,Mysql,Stored Procedures,有没有办法一次在多个MySQL数据库上轻松创建存储过程?所有数据库都在同一个MySQL安装上。我建议在每个数据库架构中进行复制粘贴并创建存储过程(如果它们需要仅对该架构可用)。否则,我将遵循“Kelly Vista”的建议,只参考其中一个模式中的存储过程。在所有模式中安装 要获取架构列表,请使用showdatabases;。将此与-使用相结合: 手动迭代模式,在继续操作时删除并取消use子句的注释,检查是否一切正常。在MySQL工作台中,Ctrl+Shift+Enter是您的朋友 在模式子集中安

有没有办法一次在多个MySQL数据库上轻松创建存储过程?所有数据库都在同一个MySQL安装上。

我建议在每个数据库架构中进行复制粘贴并创建存储过程(如果它们需要仅对该架构可用)。否则,我将遵循“Kelly Vista”的建议,只参考其中一个模式中的存储过程。

在所有模式中安装

要获取架构列表,请使用showdatabases;。将此与-使用相结合:

手动迭代模式,在继续操作时删除并取消use子句的注释,检查是否一切正常。在MySQL工作台中,Ctrl+Shift+Enter是您的朋友

在模式子集中安装例程

通常,您不希望在服务器上的所有架构中安装存储例程,而只希望在通常由已安装特定存储例程的架构集定义的子集中安装存储例程。然后,您可以使用如下查询获取相关架构的名称:

SELECT ROUTINE_SCHEMA FROM `information_schema`.`ROUTINES` where specific_name = 'MyRoutine'; 
核实

部署例程后,为了验证它们的存在,可以使用如下查询:

SELECT distinct
    r1.ROUTINE_SCHEMA, 
    case when r2.specific_name is not null then '' else '####' end as RoutineName1,
    case when r3.specific_name is not null then '' else '####' end as RoutineName2,
    case when r4.specific_name is not null then '' else '####' end as RoutineName3
FROM 
    `information_schema`.`ROUTINES` as r1 
LEFT JOIN (select * from `information_schema`.`ROUTINES` where specific_name = 'RoutineName1') as r2 on r1.routine_schema = r2.routine_schema
LEFT JOIN (select * from `information_schema`.`ROUTINES` where specific_name = 'RoutineName2') as r3 on r1.routine_schema = r3.routine_schema
LEFT JOIN (select * from `information_schema`.`ROUTINES` where specific_name = 'RoutineName3') as r4 on r1.routine_schema = r4.routine_schema
where 
    r1.specific_name = 'FilteringRoutineName'; 
此查询将检查服务器上具有例程FilteringUrtineName的数据库架构中是否存在RoutineName1、RoutineName2和RoutineName3。如果缺少一个例程,它将被标记为


当然,这只是检查常规存在。要验证它们的实现,您可能需要一个数据库差异工具,如MySQL Compare或类似工具。

假设您使用的是Linux,一个简单的BASH循环和一组模式名称将允许您这样做

将过程定义保存到一个文件,例如myproc.sql,然后将该文件用作循环中mysql的输入。如果将登录详细信息放在~/.my.cnf中,还可以避免在cmdline上输入用户名和密码

for i in dbname1 dbname2 dbname3; do mysql ${i} < myproc.sql; done;

当你说多个数据库时,你是指多个模式吗?您可以在任何模式中安装一个存储过程,并从其他模式中利用它,前提是该用户在该模式上的权限尚未被撤销;如果可能的话,可能值得研究使用存储过程的复制。我曾尝试将其自动化,但似乎不可能,因为迭代循环不能在MySQL的存储例程之外使用,和CREATE PROCEDURE语句不能在存储例程中使用。可以使用executed with EXECUTE解决此问题。稍后我将对此进行探讨,并更新我的答案以反映任何新发现。不幸的是,如果您尝试在准备好的语句中使用CREATE过程,则会得到错误代码:1295。准备好的语句协议尚不支持此命令。根据一个例子,Lua脚本语言可能很有用。
for i in dbname1 dbname2 dbname3; do mysql ${i} < myproc.sql; done;