縦型テーブル 垂直テーブル分割とは、多数の列を持つテーブルを複数のテーブルに分割することを意味します。たとえば、テーブル 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 つのファイルに対応します。 以下もご興味があるかもしれません:
|
<<: ネイティブ js を使用してライブ バレット スクリーンのスクロール効果をシミュレートします。
>>: Win10 の Linux サブシステムを有効にする方法を説明します (詳細な画像とテキスト付き)
目次dnsmasq をインストールして設定するChinaDNS をインストールして設定するshado...
FileZilla Serverをサーバーにインストールすると、425データ接続を開けない問題が発生...
1. MySQLは現在の日付と時刻を取得する関数1.1 現在の日付 + 時刻 (日付 + 時刻) ...
背景色と透明度の設定上記のように、最初の画像の場合は、灰色の背景と左上隅に白い「カバー」という文字を...
余計なことは言わないで、コードだけ見てみましょう〜 # docker-compose をダウン # ...
目次1. 反射とは何ですか? 2. JavaScriptで反映する2.1 Reflect.get(タ...
目次序文Vue CLI での設定基本コードVueルーターの登場ネストされたルートの設定要約する序文V...
目次1. はじめに2. 初期ビュー(I) Vueの概念を理解する(II) MVVMアーキテクチャ(I...
目次序文-リンクカスタムネットワーク質問する序文前回は、 -Linkパラメータを使用してコンテナ間の...
Python8のインストールを最小化した後、Python3.8.1をインストールしました。オンライン...
これを理解するおそらく、他のオブジェクト指向プログラミング言語でもthis見たことがあり、これがコン...
目次ロックの概要ロックの分類データベース操作の粒度データ操作の種類MySQL ロックさまざまなストレ...
最近、オンライン セキュリティ スキャンにより、MySQL コネクタに脆弱性が見つかりました。確認し...
最初のもの:コードをコピーコードは次のとおりです。 <html> <ヘッド>...
この記事の例では、日付と時刻の選択を実装するための uniapp の具体的なコードを参考までに共有し...