加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 站长学院 > PHP教程 > 正文

php – 一次更改多个mysql数据库(SAAS数据库更改)

发布时间:2020-12-13 18:27:04 所属栏目:PHP教程 来源:网络整理
导读:我们正在运行一个 PHP(zend框架)应用程序,它为每个用户创建一个数据库(出于安全/备份/其他原因). 所有这些数据库都具有完全相同的结构,并且始终如此.当我们部署新功能时,我们需要使用新的字段/表来扩展所有数据库. 我已经阅读过有关使用dbdeploy的内容,但我
我们正在运行一个 PHP(zend框架)应用程序,它为每个用户创建一个数据库(出于安全/备份/其他原因).
所有这些数据库都具有完全相同的结构,并且始终如此.当我们部署新功能时,我们需要使用新的字段/表来扩展所有数据库.

我已经阅读过有关使用dbdeploy的内容,但我不确定它们是否同时支持多个数据库(没有逐个列出名称).数据库称为user1,user2,user3等.

有没有什么好的工具可以让我们这个过程更轻松,更少痛苦?
我们正在为自动部署运行phing,并发现指南http://www.davedevelopment.co.uk/2008/04/14/how-to-simple-database-migrations-with-phing-and-dbdeploy/不太有用,因为它们不像我们那样支持多个数据库.

此外,我们可以使用可以执行此操作的Windows或mac mysql客户端,因此我们对任何事情都持开放态度

这是我为您准备的PHP脚本.它获取所有数据库的列表,并在数据库名称以user开头时应用更新.

我还让它在应用更改之前备份每个数据库.备份部分现在特定于Linux / Unix,但可以调整以适用于其他操作系统.

目前它非常冗长,因此您可以根据需要进行更改.您还可以更改行终止符,具体取决于您是从CLI还是浏览器运行它.我建议将它放在您的脚本目录中并从CLI运行它.

如果您需要其他任何内容或者这对您不起作用,请告诉我.

<?php
// Configure these as needed
$db_host = 'localhost';
$db_user = 'user';
$db_pass = 'password';

$datetime_pattern       = date('Ymd.His');
$backup_file_path       = "/path/to/db_backups/$datetime_pattern/";
$backup_file_format     = "db_backup.%s.sql";
$backup_syntax_pattern  = "/usr/bin/mysqldump --host=%s --user=%s --password=%s --opt %s > $backup_file_path/db_backup.%s.sql";
// !!!!!!!!!!!!!!!!!!!!!!!!!!!!
// CHANGE THE PERMISSIONS!!!!!!
// !!!!!!!!!!!!!!!!!!!!!!!!!!!!
$backup_file_permission = 0777;

// Choose how to terminate your lines
$line_end = "n";      // Use for CLI
//$line_end = "<br/>";   // Use for browser

// Match words that begin with 'user',case-insensitive
$pattern = '/^user/i';

// What changes will we be applying?
$db_update_syntax = array("ALTER TABLE foo ADD baz1 VARCHAR(30) AFTER bar1","ALTER TABLE foo ADD baz2 VARCHAR(30) AFTER bar2","ALTER TABLE foo ADD baz3 VARCHAR(30) AFTER bar3",);

// END OF CONFIGURATION
/////////////////////////////////////////////////////////////


// Create the database backup directory
if (!mkdir($backup_file_path,$backup_file_permission,true)) {
    die('Failed to create backup directory...');
}

// Connecting to MySQL.
$conn = @mysql_connect($db_host,$db_user,$db_pass)
        or die('Not connected : ' . mysql_errno() . ': ' . mysql_error());

$db_list = mysql_list_dbs($conn);

echo "{$line_end}Starting Database Update.{$line_end}";
while ($row = mysql_fetch_assoc($db_list)) {
    $db_name = $row['Database'];
    if (preg_match($pattern,$db_name)) {
        echo "{$line_end}A match was found: [$db_name]{$line_end}";
        echo "Backing up the database{$line_end}";
        // Backup the database
        $backup_syntax = sprintf($backup_syntax_pattern,$db_host,$db_pass,$db_name,$db_name);
        exec($backup_syntax);
        $db_selected = mysql_select_db($db_name,$conn)
                       or die("Can't use [$db_name] : " . mysql_error());

        foreach ($db_update_syntax as $each_update_syntax) {
            echo "Altering using: [$alter_syntax]{$line_end}";
            $update_status = mysql_query($alter_syntax);
            if ($update_status) {
                echo "Success!{$line_end}{$line_end}";
            } else {
                echo "Unable to update [$db_name] : " . mysql_error() . "{$line_end}{$line_end}";
            }
        }
    } else {
        echo "Ignoring: [$db_name]{$line_end}";
    }
}
echo "Finished!{$line_end}";
// Free resources / Close MySQL Connection
mysql_free_result($db_list);
mysql_close($conn);

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读