在 PHP 中运行 MySQL *.sql 文件:有效的解决方案
时不时地,执行 MySQL 的主题。 PHP 表面内的 sql 文件。不幸的是,没有简单的解决方案,因为 .sql 脚本通常包含无法直接作为 SQL 语句执行的命令。
边缘情况
出现边缘情况当 *.sql 脚本包含 MySQL 服务器无法识别的内置 mysql 工具命令时。这些命令包括 CONNECT、TEE、STATUS 和 DELIMITER。
可靠的方法
要解决这些挑战,建议从 PHP 调用 mysql 工具,使用类似 shell_exec() 的方法。这种方法为执行 *.sql 脚本提供了一个强大的解决方案。
示例代码:
以下示例代码演示了如何使用 shell_exec( ):
$command = "mysql --user={$vals['db_user']} --password='{$vals['db_pass']}' " . "-h {$vals['db_host']} -D {$vals['db_name']} < {$script_path}"; $output = shell_exec($command . '/shellexec.sql');
替代方法
考虑执行 *.sql 文件的替代方法的其他相关问题:
使用 shell_exec() 时请务必谨慎,避免潜在的安全风险。
以上是如何从 PHP 可靠地运行 MySQL *.sql 文件?的详细内容。更多信息请关注PHP中文网其他相关文章!