MySQL データベースでは、各 InnoDB テーブルは、テーブルのデータとインデックスを保存する .ibd ファイルに対応します。したがって、MySQL データベースの管理と保守では、ibd ファイルの管理も特に重要です。この記事では、MySQL データベース内の ibd ファイルを効果的に管理および保守する方法を紹介し、具体的なコード例を示します。
まず、次の SQL ステートメントを使用してテーブルのディスク領域の使用状況を確認します:
SELECT TABLE_NAME、 ROUND((DATA_LENGTH INDEX_LENGTH) / 1024 / 1024, 2) AS SIZE_MB から INFORMATION_SCHEMA.TABLES どこ TABLE_SCHEMA = 'database_name';
このコードは、各テーブルのサイズを理解し、不要なデータが時間内にクリーンアップされ、ディスク領域が解放されるようにするのに役立ちます。テーブルが大きすぎる場合、または大量の無駄なデータが含まれている場合は、テーブルの最適化を検討できます。
特定のテーブルのデータをあるデータベースから別のデータベースに移行する必要がある場合があります。現時点では、次の手順に従って、対応する .ibd ファイルを移行できます。
ALTER TABLE table_name IMPORT TABLESPACE;
.ibd ファイルが破損しているか異常な場合は、次の手順でファイルの修復を試みることができます。
ALTER TABLE table_name DISCARD TABLESPACE;
ALTER TABLE table_name IMPORT TABLESPACE;
テーブル スペースの使用状況を定期的に監視することが非常に必要です。次の SQL ステートメントを使用してテーブルの断片化を確認できます:
SELECT テーブル名、 データフリー から 情報スキーマ.テーブル どこ data_free > 0;
ひどく断片化したテーブルを見つけた場合は、OPTIMIZE TABLE コマンドを使用して最適化することを検討できます。
期限切れのデータ ファイルとログ ファイルの定期的なクリーンアップも、MySQL データベースを維持するための重要な操作です。次の手順でクリーンアップできます:
DELETE FROM table_name WHEREexpired_date < NOW();
PURGE BINARY LOGS BEFORE '2022-01-01';
上記の対策により、MySQL データベース内の ibd ファイルを効果的に管理および維持し、データベースの安定性とパフォーマンスを確保できます。上記の内容がお役に立てば幸いです。
以上がMySQL データベース内の ibd ファイルを効果的に管理および維持する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。