MySQLテーブルシャーディングとパーティショニングの具体的な実装方法

MySQLテーブルシャーディングとパーティショニングの具体的な実装方法

縦型テーブル

垂直テーブル分割とは、多数の列を持つテーブルを複数のテーブルに分割することを意味します。たとえば、テーブル A には 20 個のフィールドが含まれており、テーブル A1 と A2 に分割され、各テーブルに 10 個のフィールドが含まれます (具体的な分割方法はビジネスによって異なります)。

利点: 同時実行性の高いシナリオでは、テーブル ロックと行ロックの数を減らすことができます。

デメリット: データ レコードが非常に大きい場合、読み取り速度と書き込み速度に依然としてボトルネックが発生します。

水平テーブル

あるウェブサイトのデータベースに数億件のレコードを含むテーブルがある場合、SELECT でクエリを実行すると、インデックスがないとクエリが非常に遅くなります。この場合、ハッシュ アルゴリズムを使用してテーブルを 10 個のサブテーブルに分割できます (この時点で、各テーブルのデータ量は 1,000 万件のレコードのみです)。

同時に、各サブテーブルの情報を記録するための一般テーブルが生成されます。id=100 のレコードをクエリする場合、テーブル全体をスキャンする必要がなくなります。代わりに、一般テーブルを使用して、レコードが配置されている対応するサブテーブルを見つけ、対応するテーブルを検索します。これにより、IO 負荷が軽減されます。

デメリット: フロントエンド プログラム アプリケーションの SQL コードのメンテナンスに大きな問題が生じます。この場合、MySQL Merge ストレージ エンジンを使用してテーブル パーティションを実装できます。

---------------------------------------私は私に痛みを感じさせる境界線です----------------------------------------------------

Merge ストレージ エンジンを使用してテーブルをパーティション分割することは、アプリケーションの SQL ステートメントに対して透過的であり、コードを変更する必要はありません。

CREATE TABLE t1 ( a INT NOT NULL AUTO_INCREMENT PRIMARY KEY、メッセージ CHAR(20));
CREATE TABLE t2 ( a INT NOT NULL AUTO_INCREMENT PRIMARY KEY、メッセージ CHAR(20));
INSERT INTO t1 (メッセージ) VALUES ('テスト'),('テーブル'),('t1');
INSERT INTO t2 (メッセージ) VALUES ('テスト'),('テーブル'),('t2');
CREATE TABLE total (a INT NOT NULL AUTO_INCREMENT PRIMARY KEY、メッセージ CHAR(20)) ENGINE=MERGE UNION=(t1,t2) INSERT_METHOD=LAST;

合計表を作成するときに、エラーが発生する場合があります。

定義が異なる、または MyISAM 型ではない、または存在しない基礎テーブルを開くことができません

実際、マージ ストレージ エンジンは仮想テーブルであり、対応する実際のテーブルは MyISAM タイプのテーブルである必要があります。MySQL バージョンが 5.1 以上の場合、デフォルトのデータベースは InnoDB ストレージ エンジンを使用するため、合計を作成する場合、t1 テーブルと t2 テーブルは MyISAM ストレージ エンジンである必要があります。

サブテーブルを定期的に追加する必要がある場合は、マージ テーブルの結合を変更するだけで済みます。

CREATE TABLE t3( a INT NOT NULL AUTO_INCREMENT PRIMARY KEY、メッセージ CHAR(20));
ALTER TABLE 合計 UNION=(t1,t2,t3)

水平分割

たとえば、データが 100 万個ある場合、それらは 10 個の部分に分割されます。最初の 10 万個のデータは最初のパーティションに配置され、次の 10 万個のデータは 2 番目のパーティションに配置されます。データが取得されると、テーブル構造内のすべてのフィールドが含まれ、水平分割によってテーブル構造は変更されません。

垂直分割

たとえば、ユーザー テーブルを設計するときに、最初はよく考えずに、すべての個人情報を 1 つのテーブルに入れることがあります。このテーブルには、個人プロファイルなどの比較的大きなフィールドが含まれます。ただし、これらのプロファイルは多くの人に閲覧されるわけではないため、誰かが閲覧したいときには検索することになります。テーブルを分割すると、このような大きなフィールドを分離できます。

完全なテーブルは、.MYD データ ファイル、.MYI インデックス ファイル、および .frm テーブル構造ファイルの 3 つのファイルに対応します。

以下もご興味があるかもしれません:
  • MySQL の高度な機能 - データ テーブル パーティショニングの概念とメカニズムの詳細な説明
  • MySql テーブル、データベース、シャーディング、パーティショニングの知識の詳細な説明
  • MySql テーブル、データベース、シャーディング、パーティショニングの知識ポイントの紹介
  • Navicat による MySQL パーティショニングの実践
  • MySQL パーティションテーブルの正しい使用方法
  • MySQL 最適化 Zabbix パーティション最適化
  • MySQL パーティション フィールド列に別のインデックスを作成する必要がありますか?
  • MySQL データベース テーブルのパーティション分割に関する考慮事項 [推奨]
  • MySQL データ テーブル パーティション テクノロジーの簡単な分析
  • MySQL データテーブルのパーティション戦略と利点と欠点の分析

<<:  ネイティブ js を使用してライブ バレット スクリーンのスクロール効果をシミュレートします。

>>:  Win10 の Linux サブシステムを有効にする方法を説明します (詳細な画像とテキスト付き)

推薦する

CSSの絶対と相対について

冒頭にこう書かれています:アブソリュートは言った。「親戚よ、私はあなたを私の人生で見たくない!」なぜ...

MySQLインスタンスを安全にシャットダウンする方法

この記事では、mysqld プロセスをシャットダウンするプロセスと、MySQL インスタンスを安全か...

デスクトップ仮想化を実現するために Hyper-V を展開する手順 (グラフィック チュートリアル)

Hyper-V を展開するためのハードウェア要件は次のとおりです。 64 ビット プロセッサ、具体...

MySQLが正常にインストールされたかどうかを確認する方法

MySQL をインストールした後、DOS ウィンドウまたは MySQL 5.7 コマンドライン クラ...

nginx 設定ファイルパスとリソースファイルパスを表示する方法

nginx 設定ファイルのパスを表示する nginx -t 経由nginx -t コマンドの本来の機...

docker コマンド例外「権限が拒否されました」の解決方法

Linuxシステムでは、dockerを新しくインストールし、次のようなコマンドを入力します。dock...

MongoDB データベースの状態を監視する Zabbix3.4 メソッド

Mongodb には db.serverStatus() コマンドがあり、これを使用して Mongo...

Vueストレージにはブール値のソリューションが含まれています

Vueはブール値でストレージを保存します今日、問題に遭遇しました。バックグラウンドから返された真偽の...

Dockerイメージ作成の完全なプロセス

目次序文作成手順CentOSベースイメージを作成するコンテナを作成してカスタマイズするカスタムコンテ...

MySQLでレコードを変更する場合、更新操作フィールド = フィールド + 文字列

シナリオによっては、varchar 型のフィールドを変更する必要があり、変更の結果は 2 つのフィー...

Zabbixを使用してOracleテーブルスペースの操作プロセスを監視する

0. 概要Zabbix は非常に強力なオープンソースの監視ツールです。以下では、Zabbix がテー...

innerHTML アプリケーション

ブランクのブログ: http://www.planabc.net/ innerHTML プロパティは...

DockerはRedis5.0をビルドし、データをマウントします

目次1. 永続データの簡単なマウント2. DockerFileでイメージをビルドし、設定ファイルを指...

VueはWebSocketを使用してチャット機能をシミュレートします

この効果は、2つのブラウザが互いにシミュレートしていることを示しています 1. シミュレートされたノ...

nginx で gzip 圧縮を実装してウェブサイトの速度を向上させる方法

目次gzip 圧縮を使用する理由は何ですか? nginxはgzipを実装するgzip処理nginx ...