互換性なし# #####互換性がある###########実際の状況では、結果は上の表の結果と異なる場合があります。主な理由は、Innodb のロック メカニズムが非常に複雑なものであり、最終結果に影響を与えるロックが多数あるためです。
5.2.3.4 ロックの粒度:
5.2.3.5 ブロッキングとデッドロック
ブロッキング: ブロッキングは、異なるロック間の互換性関係が原因で発生します。ある時点で、あるトランザクションのロックは、別のトランザクションのロックが解放されるまで待機する必要があり、そのロックが占有するリソースによってブロッキングが形成されます。
デッドロック: デッドロックとは、トランザクションの実行中に相手が待機しているリソースを 2 つ以上のトランザクションが占有した場合に発生する例外を指します。定義からわかるように、ブロックされた複数のトランザクションがブロックされたトランザクションが待機しているリソースを占有します。デッドロックは、ブロックされた複数のトランザクションが互いに待機しているリソースを占有する場合です。
5.3 CSV ストレージ エンジン
CSV ストレージ エンジンは、csv ファイルを mysql テーブル ファイルとして処理できます。このストレージ エンジンのストレージ形式は通常の csv ファイルです。 CSV ストレージ エンジンの保存方法は非常に独特です。テーブルを MyISAM または Innodb に保存すると、これら 2 つのファイルはバイナリ形式で保存されるため、データ ファイルを直接参照できません。CSV ストレージ エンジンは異なります。CSV データは次の形式で保存されます。テキスト形式のファイル。つまり、more などのファイルを表示するコマンドを使用して表示することも、vi コマンドを使用して CSV ストレージ エンジン内のテーブルを表示および編集することもできます。形式と要件が満たされている限り、 CSV ファイルの要件を満たしている場合、データが破損することを心配する必要はありません。
mysql で CSV ストレージ エンジン テーブルを作成すると、3 つのファイル システムのファイルを確認できるようになります。これら 3 つのファイル名はすべてテーブル名に基づいていますが、接尾辞としてそれぞれ csv、csm、および frm が付いています。csv ファイルは、CSV ストレージ エンジン内のデータ ファイルです。 csm ファイルには、テーブルのメタデータ、テーブルのステータス、データ量が保存されます。 frm ファイルにはテーブル構造情報が格納されます。
5.3.1 CSV ストレージ エンジンの特徴
- 最大の特徴は、データが CSV 形式で保存されることです。
CSV の各列は ##次の図に示すように、#, で区切られ、テキストの内容は二重引用符で囲まれます。
すべての列は NULL であってはなりません - テーブルの作成時、すべての列は空であってはならず、NULL 値として保存することはできません。
インデックスはサポートされません- 大規模なテーブルやオンライン処理には適していません
データ ファイルは直接編集できます- テキスト ファイルの内容を保存する
5.3.2 CSV ストレージ エンジンの適用可能なシナリオ
CSV ストレージ エンジンはデータ交換に適しています中間テーブル
##5.4 アーカイブ ストレージ エンジン
5.4.1 ファイル システム ストレージの特性 アーカイブストレージ エンジンはすべての書き込みをキャッシュし、zlib を使用して挿入された行を圧縮します。そのため、アーカイブ ストレージ エンジンは、MyISAM ストレージ エンジンのテーブルと比較してディスク I/O を節約します。同じ桁のデータの場合、アーカイブ ストレージ エンジンは、MyISAM と比較してストレージ スペースを節約します。そしてInnodb。アーカイブ ストレージ エンジンに保存される数テラバイトの Innodb テーブルには、数百メガバイトのストレージ スペースしか必要としない場合があります。
アーカイブ ストレージ エンジンのテーブル データは、ARZ というサフィックスを持つファイルですが、他のエンジンと同様に、テーブルの構造情報を格納するために使用される frm というサフィックスを持つシステム ファイルもあります。
5.4.2 アーカイブ ストレージ エンジンの機能
insert- および
select
操作のみをサポート
自動インクリメント ID 列ではインデックスのみが許可されます
- ##5.4.3 アーカイブ ストレージ エンジンの使用シナリオ
シナリオ 1: ログおよびデータ収集クラス Data アーカイブは変更と削除をサポートしていないため、ORDB は間違いなくデータを変更しますが、一部のウェアハウス タイプのアプリケーションや、ログ テーブルやデータ収集テーブルなどの特殊なテーブルには依然として役立ちます。大量のデータを収集する必要があるため、アーカイブ ストレージ エンジンを使用します。アーカイブ ストレージ エンジンのストレージ容量はすべてのエンジンの中で最も小さいため、データ収集またはログ アプリケーションであっても、アーカイブ ストレージ エンジンはこれらのデータを更新できないことに注意してください。そのため、ログを記録するとき、またはデータ コレクション内のデータを変更する場合は、アプリケーションを使用すると、アーカイブ ストレージ エンジンを使用できない場合があります。
5.5 メモリ ストレージ エンジン
5.5.1 ファイル システム ストレージの特性
メモリ ストレージ エンジンは HEAP ストレージ エンジンとも呼ばれ、データはメモリに保存されます。これは、データ テーブルが使い捨てであることを意味します。MySQL サービスが再起動されると、すべてのメモリ ストレージ エンジンのデータが消去されます。ただし、テーブル構造はメモリ ストレージ エンジンの下でテーブルを作成すると、テーブル構造を保存するために使用される frm システム ファイルのみが生成されるため、このファイルは保持されます。これが、MySQL サーバーを再起動するとデータは失われますが、テーブル構造は失われない理由です。
ファイル ストレージの特性から、MyISAM のインデックスのみがメモリに保存され、データは MyISAM によってキャッシュされるため、メモリ ストレージ エンジンの I/O 効率は MyISAM の I/O 効率よりもはるかに高いことがわかります。オペレーティング システムとメモリ ストレージ エンジン エンジンのすべてのデータとインデックスはメモリに保存されます。メモリ ストレージ エンジンの機能的特徴を見てみましょう。
5.5.2 メモリの機能特徴
機能特徴:
-
HASH インデックス (デフォルト) とBTree Index
HASH インデックスであれば同等のクエリを実行する場合は非常に高速ですが、範囲クエリを実行する場合は HASH インデックスが使用できないため、注意が必要ですテーブルに多数の同等のクエリが必要な場合は、HASH インデックスを使用し、範囲クエリには BTree インデックスを使用します。インデックスの種類が異なると、パフォーマンスに大きな影響を与える可能性があります。
- すべてのフィールドは固定長です varchar(10) = char(10)
これには、テーブル構造を定義するときに最小フィールド長要件を満たす必要があります。満たさないと、大量のメモリが無駄になります。
- BLOG や TEXT などの大きなフィールドはサポートされません
- メモリ ストレージ エンジンはテーブル レベルのロックを使用します
- 最大サイズは max_heap_table_size パラメータによって決まります
デフォルトこのパラメータの値は 16 MB のみで、大量のデータをメモリ ストレージ エンジン テーブルに保存したい場合は、このパラメータを変更する必要があり、このパラメータの変更は既存のメモリ ストレージ エンジン テーブルには反映されません。既存のテーブルを変更する必要があり、既存のテーブルは再構築されます。
5.5.3 メモリの紛らわしい概念
メモリ ストレージ エンジン テーブル:
すべてのシステムで使用できますが、同じではありません。一時テーブル。
一時テーブル:
一時テーブルには 2 つのタイプがあります。1 つは、クエリ オプティマイザーがクエリを最適化するときにシステムによって使用される一時テーブルであり、内部一時テーブルです。システムは、制限が次の場合に一時テーブルを使用します。制限を超えていない場合は (BLOB または TEXT ラージ フィールドを使用)、MyISAM 一時テーブルを使用し、制限を超えていない場合はメモリ テーブルを使用します。
もう 1 つは、コマンド createtemporary table
によって作成された一時テーブルです。作成されたテーブルは、任意のストレージ エンジンを使用できます。
一時テーブルの種類に関係なく、内部的にのみ表示されます。
5.5.4 メモリ使用シナリオ
- は、郵便番号や地域対応テーブルなどのテーブルの検索またはマッピングに使用されます
- データ分析中に生成される中間テーブルの保存に使用されます。
- 定期集計データのキャッシュに使用される結果テーブル
メモリ データは失われやすいため、データを保存する必要があります。再現可能であること。
#5.6 Federated Storage Engine
##5.6.1 Federated の機能
リモート アクセス メソッドを提供します。 MySQL サーバー上のテーブル Federated Storage Engine はリモート サーバーへのローカル接続のみを確立するため、アクセスしたいすべてのテーブルは引き続きリモート サーバー上に配置され、データはローカルに保存されないと言えます。 Federated Storage Engine テーブルにアクセスするたびに、クエリがリモート サーバーに送信されて実行され、関連データがリモート MySQL サーバーから取得されます。 -
データはローカルに保存されず、すべてのデータはリモート サーバーに配置されます
- テーブル構造とリモート サーバーの接続情報はローカルに保存する必要があります
したがって、システム内の frm ファイルである場合は、リモート情報の保存とリモート テーブルへの接続方法に関する情報を使用します。
5.6.2 Federated の使用方法Federated Storage Engine はサーバーに接続する SQL Server の機能を実現できますが、それ自体のパフォーマンスに依存します。これはあまり良いことではありません。通常、同じ目的はレプリケーションなどを通じて達成できるため、現在の MySQL バージョンでは、フェデレーション ストレージ エンジンはデフォルトで無効になっています。 Federated Storage Engine を使用する必要がある場合は、
federated=1 を /usr/local/mysql/my.cnf
に追加して、MySQL サーバーを再起動する必要があります。 show Engine
を使用して、現在の MySQL サーバーが Federated Storage エンジンをサポートしているかどうかを確認します。 そして、
create table
ステートメントで次の接続文字列を使用します。
mysql://user_name[:password]@host_name[:port_num]/db_name/tbl_name
リモート サーバー バインディング接続:
grant select,update,insert,delete on remote.remote_fet to fred_link@'127.0.0.1'identified by '123456'
クエリ情報を決定できますリモート サーバーに関する情報と、関連するデータベース テーブルに関する情報。
5.6.3 Federated に適用できるシナリオ
時々の統計分析と手動クエリ Federated はパフォーマンスが遅いため、次の場合にのみ適しています。時々統計分析と手動クエリ。
6 正しいストレージ エンジンの選択方法参考条件:
- トランザクション
- バックアップ
- クラッシュ回復
- ストレージ エンジンの独自の機能
ストレージ エンジンを混合しないようにしてください。