MySQL InnoDBストレージエンジンについて簡単に説明します

MySQL InnoDBストレージエンジンについて簡単に説明します

序文:

ストレージ エンジンはデータベースの中核です。MySQL の場合、ストレージ エンジンはプラグインの形式で実行されます。 MySQL はさまざまなストレージ エンジンをサポートしていますが、最もよく使用されるのは InnoDB です。この記事では、主に InnoDB ストレージ エンジンに関連する知識を紹介します。

1. InnoDB の紹介

MySQL バージョン 5.5 以降では、デフォルトのストレージ エンジンは InnoDB です。 InnoDB は、高い信頼性と高いパフォーマンスを兼ね備えた汎用ストレージ エンジンです。 MySQL 5.7 では、別のデフォルトのストレージ エンジンを構成していない限り、ENGINE を指定せずに CREATE TABLE ステートメントを実行すると、InnoDB テーブルが作成されます。

# MySQL でサポートされているストレージ エンジンを表示します。mysql> show engines;
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| エンジン | サポート | コメント | トランザクション | XA | セーブポイント |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+
| InnoDB | デフォルト | トランザクション、行レベルのロック、外部キーをサポート | はい | はい | はい |
| MRG_MYISAM | YES | 同一の MyISAM テーブルのコレクション | NO | NO | NO |
| メモリ | はい | ハッシュベース、メモリに保存、一時テーブルに便利 | いいえ | いいえ | いいえ |
| BLACKHOLE | はい | /dev/null ストレージ エンジン (書き込んだものはすべて消えます) | いいえ | いいえ | いいえ |
| MyISAM | はい | MyISAM ストレージ エンジン | いいえ | いいえ | いいえ |
| CSV | はい | CSV ストレージ エンジン | いいえ | いいえ | いいえ |
| アーカイブ | はい | アーカイブ ストレージ エンジン | いいえ | いいえ | いいえ |
| PERFORMANCE_SCHEMA | YES | パフォーマンス スキーマ | NO | NO | NO |
| FEDERATED | NO | フェデレーテッド MySQL ストレージ エンジン | NULL | NULL | NULL |
+--------------------+---------+----------------------------------------------------------------+--------------+------+------------+

# デフォルトのストレージ エンジンを表示します。mysql> show variables like 'default_storage_engine';
+------------------------+--------+
| 変数名 | 値 |
+------------------------+--------+
| デフォルトのストレージエンジン | InnoDB |
+------------------------+--------+

2. InnoDBの利点

InnoDB がこれほど人気が​​あるのは、主にその多くの機能上の利点によるものです。

1) サポートサービス

InnoDB の最も重要な点は、トランザクションをサポートしていることです。これが、InnoDB が MySQL で最も人気のあるストレージ エンジンになった非常に重要な理由であると言えます。さらに、InnoDB は 4 つの分離レベル (READ UNCOMMITTED、READ COMMITTED、REPEATABLE READ、SERIALIZABLE) も実装しており、トランザクションのサポートがより柔軟になっています。

2) 優れた災害復旧

InnoDB は、コミット、ロールバック、クラッシュリカバリを通じてデータのセキュリティを確保します。

具体的には、クラッシュリカバリとは、ハードウェアまたはソフトウェアの問題によりサーバーがクラッシュした場合、その時点のデータがどのような状態であっても、MySQL を再起動すると、InnoDB がクラッシュ前の状態に自動的に回復することを意味します。

3) 行レベルのロックを使用する

InnoDB は MyISAM のロック メカニズムを変更し、行ロックを実装します。 InnoDB の行ロック メカニズムはインデックスを通じて実装されていますが、データベース内のほとんどの SQL ステートメントはインデックスを使用してデータを取得します。行ロック メカニズムにより、同時実行のプレッシャーが高い環境でも InnoDB の競争力が大幅に向上します。

4) バッファ処理を実装

InnoDB は専用のバッファプールを提供し、バッファ管理を実装しています。インデックスだけでなく、データもバッファリングできます。頻繁に使用されるデータはメモリから直接処理できるため、ディスクからデータを取得するよりも高速です。専用データベース サーバーでは、物理メモリの最大 80% をバッファー プールに割り当てるのが一般的です。

5) 外部キーをサポートする

InnoDB は、外部キー制約、外部キーのチェック、挿入、更新、削除をサポートし、データの整合性を保証します。テーブルにデータを格納する際、各テーブルは主キーの順序で格納されます。テーブルの定義時に主キーが明示的に指定されていない場合、InnoDB は行ごとに 6 バイトの ROWID を生成し、それを主キーとして使用します。

要約:

この記事では、InnoDB ストレージ エンジンとその利点について簡単に説明します。MySQL を深く学びたい場合、InnoDB は絶対に避けて通れない重要な知識です。 InnoDB については他にもたくさんのコンテンツがあるので、機会があれば後ほど詳しく書きたいと思います。

上記はMySQL InnoDBストレージエンジンの詳細についての簡単な説明です。MySQL InnoDBストレージエンジンの詳細については、123WORDPRESS.COMの他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • MySQL InnoDB アーキテクチャの概要
  • MySQL InnoDB ReplicaSet の簡単な紹介
  • MySQL InnoDB ストレージエンジンのメモリ管理の詳細な説明
  • MySQL Innodbの主な機能挿入バッファ
  • MySQL InnoDB ロックの概要
  • MySQL の innodb_flush_log_at_trx_commit と sync_binlog を区別する方法
  • MySQL InnoDB ロック メカニズムの詳細な例
  • MySQLテクノロジーにおけるInnoDBロックの詳細な説明
  • MySQLデータベースエンジンをInnoDBに変更する
  • MySQL InnoDB テーブルスペース暗号化の例の詳細な説明
  • MySQL InnoDB トランザクション ロック ソースコード分析

<<:  Vue3 ドキュメント クイックスタート

>>:  Linux QT Kit が見つからない、バージョンが空の問題の解決策

推薦する

CSS3 の display:grid、グリッドレイアウトの紹介

1. グリッドレイアウト(グリッド): Web ページをグリッドに分割し、さまざまなグリッドを組み合...

MySQL ストアド プロシージャ関連の権限変更の問題

MySQL データベースを使用すると、他のユーザーが定義したストアド プロシージャを他のユーザーが変...

Vue はトークンの有効期限が切れると自動的にログインページにジャンプする機能を実装します

このプロジェクトは最近テストされ、テスターから、トークンの有効期限が切れたため、ルートが自動的にログ...

MySQLの一般クエリログとスロークエリログの分析

MySQL のログには、エラー ログ、バイナリ ログ、一般クエリ ログ、スロー クエリ ログなどが含...

dockerコンテナがIP経由でホストマシンにアクセスできない問題を解決する方法の詳細な説明

問題の起源docker を使用する場合、残念ながら docker コンテナ内のホストのポート 80 ...

XHTML 入門チュートリアル: XHTML ハイパーリンク

ハイパーリンクはインターネット全体を接続していると言っても過言ではありません。ハイパーリンクは、別の...

MySQL 結合テーブルと ID 自動増分の例の分析

結合の書き方左結合を使用する場合、左側のテーブルが必ず駆動テーブルになりますか? 2 つのテーブルの...

Vue3 シングルファイルコンポーネントのスタイル機能の詳細な説明

目次スタイルスコープスタイルモジュール状態駆動型動的CSS要約するスタイルスコープ注意事項:スタイル...

HTML2 キャンバス SVG が認識されない場合の解決策

ウェブページを画像としてキャプチャする新機能があったので、人気のhtml2canvasを使ってみまし...

Dockerコンテナの紹介

1. 概要1.1 基本概念: Docker は、Go 言語をベースにしたオープンソースのアプリケーシ...

mysql-8.0.16 winx64 最新インストール チュートリアル (画像とテキスト付き)

最近、データベースについて学び始めました。最初にやったことは、データベースとは何か、データベースとデ...

経験豊富な人が、プロフェッショナルで標準化されたMySQL起動スクリプトの開発方法を紹介します。

シェル スクリプト言語は、すべてのプログラミング言語の中で最も単純な言語であるため、資格のある Li...

Docker 経由で Redis 6.x クラスターをデプロイする方法

システム環境: Redis バージョン: 6.0.8 Docker バージョン: 19.03.12シ...

Vue で動的に追加されたルーティング ページの更新時に失敗する理由と解決策

目次問題の説明シナリオインターフェースリターンフロントエンドメニューの定義vuex のメソッド問題原...

Win7 64 ビット版に MySQL 5.7 をダウンロードしてインストールする際によくある問題の概要

1. 公式ウェブサイトからMySQLをダウンロードします。 これが私たちが探しているものです、win...