gpt4 book ai didi

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

转载 作者:可可西里 更新时间:2023-11-01 12:48:08 25 4
gpt4 key购买 nike

我们正在运行一个 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_user, $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);

关于php - 一次更改多个 mysql 数据库(SAAS 数据库更改),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3219454/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com