这是我所拥有的信息:
我正在使用MySQL和PHP5在基于Linux的系统上工作。我需要能够mysqldump
从.php文件中生成一个,然后将该转储存储在服务器上的文件中我要指定的位置。
因为我是PHP nooblet,所以我希望有人给我一些帮助,指导或代码,这些可以帮助我完成所需的工作。这将必须从Internet远程运行。
这是我所拥有的信息:
我正在使用MySQL和PHP5在基于Linux的系统上工作。我需要能够mysqldump
从.php文件中生成一个,然后将该转储存储在服务器上的文件中我要指定的位置。
因为我是PHP nooblet,所以我希望有人给我一些帮助,指导或代码,这些可以帮助我完成所需的工作。这将必须从Internet远程运行。
Answers:
您可以使用该exec()
功能执行外部命令。
注意:在shell_exec()
和之间exec()
,我会选择第二个,它不会将输出返回到PHP脚本-不需要PHP脚本以字符串的形式获取整个SQL转储:您只需要将其写入文件中,这可以通过命令本身来完成。
该外部命令将:
mysqldump
使用正确的参数致电,例如 :
mysqldump --user=... --password=... --host=... DB_NAME > /path/to/output/file.sql
这意味着您的PHP代码将如下所示:
exec('mysqldump --user=... --password=... --host=... DB_NAME > /path/to/output/file.sql');
当然,由您决定使用正确的连接信息,用...
那些代替。
exec()
在命令完成前不会返回; 因此,echo "dump complete"
在致电后才放一些exec()
/usr/local/mysql/bin/mysqldump
exec("C:/pathto/mysql/bin/mysqldump.exe <options as above>");
如果要创建备份以通过浏览器下载,也可以不使用文件来执行此操作。
php函数passthru()将直接将mysqldump的输出重定向到浏览器。在此示例中,它也会被压缩。
优点:您不必处理临时文件。
缺点:在Windows上无法使用。庞大的数据集可能会有限制。
<?php
$DBUSER="user";
$DBPASSWD="password";
$DATABASE="user_db";
$filename = "backup-" . date("d-m-Y") . ".sql.gz";
$mime = "application/x-gzip";
header( "Content-Type: " . $mime );
header( 'Content-Disposition: attachment; filename="' . $filename . '"' );
$cmd = "mysqldump -u $DBUSER --password=$DBPASSWD $DATABASE | gzip --best";
passthru( $cmd );
exit(0);
?>
在这里看看:https : //github.com/ifsnop/mysqldump-php!这是用php编写的本机解决方案。
您可以使用composer进行安装,它非常简单:
<?php
use Ifsnop\Mysqldump as IMysqldump;
try {
$dump = new IMysqldump\Mysqldump('database', 'username', 'password');
$dump->start('storage/work/dump.sql');
} catch (\Exception $e) {
echo 'mysqldump-php error: ' . $e->getMessage();
}
?>
它支持高级用户,并从原始mysqldump复制了许多选项。
所有选项都在github页面上进行了说明,但是或多或少都是自动说明性的:
$dumpSettingsDefault = array(
'include-tables' => array(),
'exclude-tables' => array(),
'compress' => 'None',
'no-data' => false,
'add-drop-database' => false,
'add-drop-table' => false,
'single-transaction' => true,
'lock-tables' => false,
'add-locks' => true,
'extended-insert' => true,
'disable-foreign-keys-check' => false,
'where' => '',
'no-create-info' => false
);
请转至以下链接,该链接包含可帮助您的脚本:http : //davidwalsh.name/backup-mysql-database-php
注意:此脚本可能包含数据类型为NULL的错误
出于安全原因,建议在配置文件中而不是在命令中指定密码(用户可以执行ps aux | grep mysqldump
并查看密码)。
//create a temporary file
$file = tempnam(sys_get_temp_dir(), 'mysqldump');
//store the configuration options
file_put_contents($file, "[mysqldump]
user={$user}
password=\"{$password}\"");
//execute the command and output the result
passthru("mysqldump --defaults-file=$file {$dbname}");
//delete the temporary file
unlink($file);
在这里,您可以找到一个全面的解决方案,像在PMA中一样转储mysql结构和数据(并且无需使用exec,passthru等):
https://github.com/antarasi/MySQL-Dump-with-Foreign-keys
它是dszymczuk项目的分支,具有我的增强功能。
用法很简单
<?php
//MySQL connection parameters
$dbhost = 'localhost';
$dbuser = 'dbuser';
$dbpsw = 'pass';
$dbname = 'dbname';
//Connects to mysql server
$connessione = @mysql_connect($dbhost,$dbuser,$dbpsw);
//Set encoding
mysql_query("SET CHARSET utf8");
mysql_query("SET NAMES 'utf8' COLLATE 'utf8_general_ci'");
//Includes class
require_once('FKMySQLDump.php');
//Creates a new instance of FKMySQLDump: it exports without compress and base-16 file
$dumper = new FKMySQLDump($dbname,'fk_dump.sql',false,false);
$params = array(
//'skip_structure' => TRUE,
//'skip_data' => TRUE,
);
//Make dump
$dumper->doFKDump($params);
?>
奇迹般有效 :-)
MajorLeo的答案为我指明了正确的方向,但对我没有用。我发现该网站遵循相同的方法并且可以正常工作。
$dir = "path/to/file/";
$filename = "backup" . date("YmdHis") . ".sql.gz";
$db_host = "host";
$db_username = "username";
$db_password = "password";
$db_database = "database";
$cmd = "mysqldump -h {$db_host} -u {$db_username} --password={$db_password} {$db_database} | gzip > {$dir}{$filename}";
exec($cmd);
header("Content-type: application/octet-stream");
header("Content-Disposition: attachment; filename=\"$filename\"");
passthru("cat {$dir}{$filename}");
我希望它可以帮助其他人!
好吧,您始终可以使用PHP的系统函数调用。
http://php.net/manual/zh/function.system.php
http://www.php.net/manual/zh/function.exec.php
那可以从PHP运行任何命令行程序。
这是另一个基于PHP的本机选项:https : //github.com/2createStudio/shuttle-export
global $wpdb;
$export_posts = $wpdb->prefix . 'export_posts';
$backupFile = $_GET['targetDir'].'export-gallery.sql';
$dbhost=DB_HOST;
$dbuser=DB_USER;
$dbpass=DB_PASSWORD;
$db=DB_NAME;
$path_to_mysqldump = "D:\xampp_5.6\mysql\bin";
$query= "D:\\xampp_5.6\mysql\bin\mysqldump.exe -u$dbuser -p$dbpass $db $export_posts> $backupFile";
exec($query);
echo $query;
以上代码均不适用于我。我正在使用Windows。下面的代码为我工作...
$sql = "SELECT * FROM $tableName WHERE yourclause";
$result = $conn->query($sql);
if($result){
if ($result->num_rows > 0) {
$myfile = fopen("daily_events_$district.sql", "w") or die("Unable to open file!");
while($row = $result->fetch_assoc()) {
$rowToString = implode("','",$row);
$writeToFile = "INSERT INTO $tableName VALUES('$rowToString');". PHP_EOL;
fwrite($myfile,$writeToFile);
}
echo "File saved successfully";
}
} else {
echo "No result found";
}
它将根据您的查询将文件保存到您的项目文件夹中,无论您需要什么数据。
<?php
$toDay = date('d-m-Y');
$dbhost = "localhost";
$dbuser = "YOUR DB USER";
$dbpass = "USER PASSWORD";
$dbname = "DB NAME";
exec("mysqldump --user=$dbuser --password='$dbpass' --host=$dbhost $dbname > /home/....../public_html/".$toDay."_DB.sql");
?>
mysqldump
的system()
。