dsjlqkbpn029473708 2018-03-24 07:47
浏览 23
已采纳

以编程方式更新多个数据库中的相同过程

I have procedure MY_OWN_PROC with parameters _DATE, _ID and its body is:

BEGIN
SELECT h.* 
FROM `my` h 
WHERE     
    h.DATE>=_DATE /*comment*/;
END

I have the same procedure in databases db1 - db100. Now I would like to update body of procedure in all databases at once (e.g. I want to replace "h.DATE<_DATE" part or the whole body). How can this be done with mysql by native sql command, or by adminer (I am using adminer on the server) or by php script please?

Update: First my thought - I will make sql command for the 100 databases (copy/paste) and the copy this huge command to adminer and run it.

  • 写回答

1条回答 默认 最新

  • dongxian1921 2018-03-24 09:08
    关注

    If your database user has access to all of the databases, the you can create a PHP for loop

    $conn = new mysqli ( '172.17.0.3', 'root', 'root', 'test');
    for ( $i = 1; $i < 101; $i++ )  {
            if ($conn->query("CREATE DEFINER=`root`@`%` PROCEDURE `db$i`.`MY_OWN_PROC`(IN `_DATE` INT)
            NO SQL
        SELECT h.* 
    FROM `my` h 
    WHERE     
        h.DATE>=_DATE") === false )  {
                echo "error:".$conn->error;
            }
        }
    

    The main thing here is the db$i.MY_OWN_PROC bit which puts the increment into the database name.

    You will of course have to put the correct source for your procedure into the code and the correct database credentials.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 请问有人会紧聚焦相关的matlab知识嘛?
  • ¥15 网络通信安全解决方案
  • ¥50 yalmip+Gurobi
  • ¥20 win10修改放大文本以及缩放与布局后蓝屏无法正常进入桌面
  • ¥15 itunes恢复数据最后一步发生错误
  • ¥15 关于#windows#的问题:2024年5月15日的win11更新后资源管理器没有地址栏了顶部的地址栏和文件搜索都消失了
  • ¥100 H5网页如何调用微信扫一扫功能?
  • ¥15 讲解电路图,付费求解
  • ¥15 有偿请教计算电磁学的问题涉及到空间中时域UTD和FDTD算法结合的
  • ¥15 three.js添加后处理以后模型锯齿化严重