PHP での MySQL *.sql ファイルの実行
Web サイトのデータベースを作成する場合、 を実行する必要があるシナリオが発生する場合があります。 PHP から SQL ファイルをダウンロードしてサイト生成を自動化します。 Zend_Framework は有益ですが、.sql ファイルを PHP から直接実行するのは、SQL ステートメントの不一致のため困難な場合があります。
解決策:shell_exec() を使用する
推奨されるアプローチは、shell_exec() を使用して mysql ツールを呼び出し、*.sql スクリプトを実行することです。以下に例を示します。
$command = 'mysql' . ' --host=' . $vals['db_host'] . ' --user=' . $vals['db_user'] . ' --password=' . $vals['db_pass'] . ' --database=' . $vals['db_name'] . ' --execute="SOURCE ' . $script_path ;
このコマンドは、$script_path で指定された *.sql ファイルを実行するために必要なパラメータを持つ MySQL 実行コマンドを作成します。
shell_exec() の違いおよび exec()
どちらの関数も外部コマンドを実行しますが、いくつかの違いがあります。 shell_exec() はコマンドの出力をキャプチャして文字列として返し、exec() はコマンドの実行ステータスを返します。この場合、MySQL コマンドの出力を取得するには、shell_exec() を使用することをお勧めします。
追加の考慮事項
*.sql ファイルを実行するときは、コマンドにすべてのファイルが含まれていることを確認してください。必要なパラメータ (db_host、db_user、db_pass、db_name) があり、スクリプトを実行するための十分な権限があること。さらに、< の代わりに --execute="SOURCE ..." オプションを使用します。ファイルを実行します。
以上がshell_exec() を使用して PHP から MySQL *.sql ファイルを実行するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。