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