MySQL ダンプ ファイルから DEFINER 句を削除するにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2024-10-28 21:57:30
オリジナル
945 人が閲覧しました

How to Remove DEFINER Clauses from MySQL Dump Files?

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

MySQL ダンプ ファイルには、多くの場合、「DEFINER=root@localhost」などの DEFINER 句が含まれています。特定のデータベース オブジェクトの作成を担当するユーザーとホスト。これらの句はデバッグ目的で貴重な情報を提供しますが、セキュリティ上の問題が生じたり、移植性が妨げられる可能性もあります。

ダンプ ファイルから DEFINER 句を削除

残念ながら、ダンプ ファイルからの DEFINER 句の削除はありません。ダンプ プロセスから DEFINER 句を除外する直接的な方法。ただし、ダンプ ファイルの作成後にそれらを削除するには、いくつかの方法があります。

  • テキスト エディターでの手動削除: テキスト エディターでダンプ ファイルを開き、すべてを手動で置き換えます。空の文字列「」を持つ「DEFINER=root@localhost」のインスタンス。
  • Perl スクリプト: 次の Perl コマンドを使用して、ダンプ ファイルを編集します (またはその出力をパイプ処理します):
perl -p -i.bak -e "s/DEFINER=\`\w.*\`@\`\d[0-3].*[0-3]\`//g" mydatabase.sql
ログイン後にコピー
  • Sed コマンド: sed を介してダンプ出力をパイプします:
mysqldump ... | sed -e 's/DEFINER[ ]*=[ ]*[^*]*\*/\*/' > triggers_backup.sql
ログイン後にコピー

これらのメソッドを利用することで、データベース管理者は効果的にMySQL ダンプ ファイルから DEFINER 句を削除し、データベースの機能的整合性を維持しながらセキュリティと移植性の問題に対処します。

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

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