MySQL ダンプからの DEFINER 句の削除
MySQL ダンプには、多くの場合、CREATE VIEW ステートメントと CREATE PROCEDURE ステートメント内に「DEFINER=root」などの DEFINER 句が含まれています。 @ローカルホスト」。これらの条項は、特定のシナリオでは望ましくない場合があります。この記事では、MySQL ダンプ ファイルからこれらの句を削除する方法について説明します。
解決策:
ダンプ ファイルをテキスト エディタで開き、グローバル検索と置換を実行します。 「DEFINER=
次のコマンドを使用して Perl を使用してダンプ ファイルを編集します:
perl -p -i.bak -e "s/DEFINER=\`\w.*\`@\`\d[0-3].*[0-3]\`//g" mydatabase.sql
これにより、ダンプ ファイルからすべての DEFINER 句が削除され、「.bak」拡張子の付いたバックアップが作成されます。
mysqldump の出力を sed にパイプして、DEFINER 句を削除します。
mysqldump ... | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/' > triggers_backup.sql
このコマンドは、DEFINER 句が削除された「triggers_backup.sql」という名前の新しいダンプ ファイルを作成します。
以上がMySQL ダンプから DEFINER 句を削除するには?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。