MySQL ダンプから DEFINER 句を削除するには?

Susan Sarandon
リリース: 2024-10-27 07:11:29
オリジナル
725 人が閲覧しました

How to Remove DEFINER Clauses from MySQL Dumps?

MySQL ダンプからの DEFINER 句の削除

MySQL ダンプには、多くの場合、CREATE VIEW ステートメントと CREATE PROCEDURE ステートメント内に「DEFINER=root」などの DEFINER 句が含まれています。 @ローカルホスト」。これらの条項は、特定のシナリオでは望ましくない場合があります。この記事では、MySQL ダンプ ファイルからこれらの句を削除する方法について説明します。

解決策:

  1. テキスト エディタの置換:

ダンプ ファイルをテキスト エディタで開き、グローバル検索と置換を実行します。 「DEFINER=@」のすべてのインスタンスを検索します。

  1. Perl コマンド:

次のコマンドを使用して Perl を使用してダンプ ファイルを編集します:

perl -p -i.bak -e "s/DEFINER=\`\w.*\`@\`\d[0-3].*[0-3]\`//g" mydatabase.sql
ログイン後にコピー

これにより、ダンプ ファイルからすべての DEFINER 句が削除され、「.bak」拡張子の付いたバックアップが作成されます。

  1. Sed Piping:

mysqldump の出力を sed にパイプして、DEFINER 句を削除します。

mysqldump ... | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/' > triggers_backup.sql
ログイン後にコピー

このコマンドは、DEFINER 句が削除された「triggers_backup.sql」という名前の新しいダンプ ファイルを作成します。

以上がMySQL ダンプから DEFINER 句を削除するには?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!