ホームページ データベース mysql チュートリアル MySQL不同存储引擎和不同分区字段对于查询的影响_MySQL

MySQL不同存储引擎和不同分区字段对于查询的影响_MySQL

Jun 01, 2016 pm 01:36 PM
影響

bitsCN.com

MySQL不同存储引擎和不同分区字段对于查询的影响

 

前提:每种表类型准备了200万条相同的数据。

表一 InnoDB & PARTITION BY RANGE (id) 

Sql代码      

CREATE TABLE `customer_innodb_id` (  

  `id` int(11) NOT NULL,  

  `email` varchar(64) NOT NULL,  

  `name` varchar(32) NOT NULL,  

  `password` varchar(32) NOT NULL,  

  `phone` varchar(13) DEFAULT NULL,  

  `birth` date DEFAULT NULL,  

  `sex` int(1) DEFAULT NULL,  

  `avatar` blob,  

  `address` varchar(64) DEFAULT NULL,  

  `regtime` datetime DEFAULT NULL,  

  `lastip` varchar(15) DEFAULT NULL,  

  `modifytime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,  

  PRIMARY KEY (`id`)  

) ENGINE=InnoDB DEFAULT CHARSET=utf8  

/*!50100 PARTITION BY RANGE (id)  

(PARTITION p0 VALUES LESS THAN (100000) ENGINE = InnoDB,  

 PARTITION p1 VALUES LESS THAN (500000) ENGINE = InnoDB,  

 PARTITION p2 VALUES LESS THAN (1000000) ENGINE = InnoDB,  

 PARTITION p3 VALUES LESS THAN (1500000) ENGINE = InnoDB,  

 PARTITION p4 VALUES LESS THAN (2000000) ENGINE = InnoDB,  

 PARTITION p5 VALUES LESS THAN MAXVALUE ENGINE = InnoDB) */;  

 

查询结果:    

Sql代码  

mysql> select count(*) from customer_innodb_id where id > 50000 and id

  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (1.19 sec)  

  

mysql> select count(*) from customer_innodb_id where id > 50000 and id

  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (0.28 sec)  

  

mysql> select count(*) from customer_innodb_id where regtime > '1995-01-01 00:00  

:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (4.74 sec)  

  

mysql> select count(*) from customer_innodb_id where regtime > '1995-01-01 00:00  

:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (5.28 sec)  

 

表二 InnoDB & PARTITION BY RANGE (year) 

Sql代码  

CREATE TABLE `customer_innodb_year` (  

  `id` int(11) NOT NULL,  

  `email` varchar(64) NOT NULL,  

  `name` varchar(32) NOT NULL,  

  `password` varchar(32) NOT NULL,  

  `phone` varchar(13) DEFAULT NULL,  

  `birth` date DEFAULT NULL,  

  `sex` int(1) DEFAULT NULL,  

  `avatar` blob,  

  `address` varchar(64) DEFAULT NULL,  

  `regtime` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',  

  `lastip` varchar(15) DEFAULT NULL,  

  `modifytime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,  

  PRIMARY KEY (`id`,`regtime`)  

) ENGINE=InnoDB DEFAULT CHARSET=utf8  

/*!50100 PARTITION BY RANGE (YEAR(regtime ))  

(PARTITION p0 VALUES LESS THAN (1996) ENGINE = InnoDB,  

 PARTITION p1 VALUES LESS THAN (1997) ENGINE = InnoDB,  

 PARTITION p2 VALUES LESS THAN (1998) ENGINE = InnoDB,  

 PARTITION p3 VALUES LESS THAN (1999) ENGINE = InnoDB,  

 PARTITION p4 VALUES LESS THAN (2000) ENGINE = InnoDB,  

 PARTITION p5 VALUES LESS THAN (2001) ENGINE = InnoDB,  

 PARTITION p6 VALUES LESS THAN (2002) ENGINE = InnoDB,  

 PARTITION p7 VALUES LESS THAN (2003) ENGINE = InnoDB,  

 PARTITION p8 VALUES LESS THAN (2004) ENGINE = InnoDB,  

 PARTITION p9 VALUES LESS THAN (2005) ENGINE = InnoDB,  

 PARTITION p10 VALUES LESS THAN (2006) ENGINE = InnoDB,  

 PARTITION p11 VALUES LESS THAN (2007) ENGINE = InnoDB,  

 PARTITION p12 VALUES LESS THAN (2008) ENGINE = InnoDB,  

 PARTITION p13 VALUES LESS THAN (2009) ENGINE = InnoDB,  

 PARTITION p14 VALUES LESS THAN (2010) ENGINE = InnoDB,  

 PARTITION p15 VALUES LESS THAN (2011) ENGINE = InnoDB,  

 PARTITION p16 VALUES LESS THAN (2012) ENGINE = InnoDB,  

 PARTITION p17 VALUES LESS THAN (2013) ENGINE = InnoDB,  

 PARTITION p18 VALUES LESS THAN (2014) ENGINE = InnoDB,  

 PARTITION p19 VALUES LESS THAN MAXVALUE ENGINE = InnoDB) */;  

 

查询结果:

Sql代码  

mysql> select count(*) from customer_innodb_year where id > 50000 and id

0;  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (5.31 sec)  

  

mysql> select count(*) from customer_innodb_year where id > 50000 and id

0;  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (0.31 sec)  

  

mysql> select count(*) from customer_innodb_year where regtime > '1995-01-01 00:  

00:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (0.47 sec)  

  

mysql> select count(*) from customer_innodb_year where regtime > '1995-01-01 00:  

00:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (0.19 sec)  

 

表三 MyISAM & PARTITION BY RANGE (id) 

Sql代码  

CREATE TABLE `customer_myisam_id` (  

  `id` int(11) NOT NULL,  

  `email` varchar(64) NOT NULL,  

  `name` varchar(32) NOT NULL,  

  `password` varchar(32) NOT NULL,  

  `phone` varchar(13) DEFAULT NULL,  

  `birth` date DEFAULT NULL,  

  `sex` int(1) DEFAULT NULL,  

  `avatar` blob,  

  `address` varchar(64) DEFAULT NULL,  

  `regtime` datetime DEFAULT NULL,  

  `lastip` varchar(15) DEFAULT NULL,  

  `modifytime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,  

  PRIMARY KEY (`id`)  

) ENGINE=MyISAM DEFAULT CHARSET=utf8  

/*!50100 PARTITION BY RANGE (id)  

(PARTITION p0 VALUES LESS THAN (100000) ENGINE = MyISAM,  

 PARTITION p1 VALUES LESS THAN (500000) ENGINE = MyISAM,  

 PARTITION p2 VALUES LESS THAN (1000000) ENGINE = MyISAM,  

 PARTITION p3 VALUES LESS THAN (1500000) ENGINE = MyISAM,  

 PARTITION p4 VALUES LESS THAN (2000000) ENGINE = MyISAM,  

 PARTITION p5 VALUES LESS THAN MAXVALUE ENGINE = MyISAM) */;  

 

查询结果:

Sql代码  

mysql> select count(*) from customer_myisam_id where id > 50000 and id

  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (0.59 sec)  

  

mysql> select count(*) from customer_myisam_id where id > 50000 and id

  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (0.16 sec)  

  

mysql> select count(*) from customer_myisam_id where regtime > '1995-01-01 00:00  

:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (34.17 sec)  

  

mysql> select count(*) from customer_myisam_id where regtime > '1995-01-01 00:00  

:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (34.06 sec)  

 

表四 MyISAM & PARTITION BY RANGE (year) 

Sql代码  

CREATE TABLE `customer_myisam_year` (  

  `id` int(11) NOT NULL,  

  `email` varchar(64) NOT NULL,  

  `name` varchar(32) NOT NULL,  

  `password` varchar(32) NOT NULL,  

  `phone` varchar(13) DEFAULT NULL,  

  `birth` date DEFAULT NULL,  

  `sex` int(1) DEFAULT NULL,  

  `avatar` blob,  

  `address` varchar(64) DEFAULT NULL,  

  `regtime` datetime NOT NULL DEFAULT '0000-00-00 00:00:00',  

  `lastip` varchar(15) DEFAULT NULL,  

  `modifytime` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP,  

  PRIMARY KEY (`id`,`regtime`)  

) ENGINE=MyISAM DEFAULT CHARSET=utf8  

/*!50100 PARTITION BY RANGE (YEAR(regtime ))  

(PARTITION p0 VALUES LESS THAN (1996) ENGINE = MyISAM,  

 PARTITION p1 VALUES LESS THAN (1997) ENGINE = MyISAM,  

 PARTITION p2 VALUES LESS THAN (1998) ENGINE = MyISAM,  

 PARTITION p3 VALUES LESS THAN (1999) ENGINE = MyISAM,  

 PARTITION p4 VALUES LESS THAN (2000) ENGINE = MyISAM,  

 PARTITION p5 VALUES LESS THAN (2001) ENGINE = MyISAM,  

 PARTITION p6 VALUES LESS THAN (2002) ENGINE = MyISAM,  

 PARTITION p7 VALUES LESS THAN (2003) ENGINE = MyISAM,  

 PARTITION p8 VALUES LESS THAN (2004) ENGINE = MyISAM,  

 PARTITION p9 VALUES LESS THAN (2005) ENGINE = MyISAM,  

 PARTITION p10 VALUES LESS THAN (2006) ENGINE = MyISAM,  

 PARTITION p11 VALUES LESS THAN (2007) ENGINE = MyISAM,  

 PARTITION p12 VALUES LESS THAN (2008) ENGINE = MyISAM,  

 PARTITION p13 VALUES LESS THAN (2009) ENGINE = MyISAM,  

 PARTITION p14 VALUES LESS THAN (2010) ENGINE = MyISAM,  

 PARTITION p15 VALUES LESS THAN (2011) ENGINE = MyISAM,  

 PARTITION p16 VALUES LESS THAN (2012) ENGINE = MyISAM,  

 PARTITION p17 VALUES LESS THAN (2013) ENGINE = MyISAM,  

 PARTITION p18 VALUES LESS THAN (2014) ENGINE = MyISAM,  

 PARTITION p19 VALUES LESS THAN MAXVALUE ENGINE = MyISAM) */;  

 

查询结果:

Sql代码  

mysql> select count(*) from customer_myisam_year where id > 50000 and id

0;  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (2.08 sec)  

  

mysql> select count(*) from customer_myisam_year where id > 50000 and id

0;  

+----------+  

| count(*) |  

+----------+  

|   449999 |  

+----------+  

1 row in set (0.17 sec)  

  

mysql> select count(*) from customer_myisam_year where regtime > '1995-01-01 00:  

00:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (0.56 sec)  

  

mysql> select count(*) from customer_myisam_year where regtime > '1995-01-01 00:  

00:00' and regtime

+----------+  

| count(*) |  

+----------+  

|   199349 |  

+----------+  

1 row in set (0.13 sec)  

 

 结果汇总    

序号 存储引擎 分区函数 查询条件 一次查询(sec) 二次查询(sec)

1 InnoDB id id 1.19 0.28

2 InnoDB id regtime 4.74 5.28

3 InnoDB year id 5.31 0.31

4 InnoDB year regtime 0.47 0.19

5 MyISAM id id 0.59 0.16

6 MyISAM id regtime 34.17 34.06

7 MyISAM year id 2.08 0.17

8 MyISAM year regtime 0.56 0.13

 总结

1、对于按照时间区间来查询的,建议采用按照时间来分区,减少查询范围。

2、MyISAM性能总体占优,但是不支持事务处理、外键约束等。

 

bitsCN.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

VBOX_E_OBJECT_NOT_FOUND(0x80bb0001)VirtualBox エラー VBOX_E_OBJECT_NOT_FOUND(0x80bb0001)VirtualBox エラー Mar 24, 2024 am 09:51 AM

VirtualBox でディスク イメージを開こうとすると、ハード ドライブを登録できないことを示すエラーが発生する場合があります。これは通常、開こうとしている VM ディスク イメージ ファイルが別の仮想ディスク イメージ ファイルと同じ UUID を持つ場合に発生します。この場合、VirtualBox はエラー コード VBOX_E_OBJECT_NOT_FOUND(0x80bb0001) を表示します。このエラーが発生した場合でも、心配する必要はありません。試すことができる解決策がいくつかあります。まず、VirtualBox のコマンド ライン ツールを使用して、ディスク イメージ ファイルの UUID を変更してみてください。これにより、競合が回避されます。コマンド「VBoxManageinternal」を実行できます。

機内モードを使用した電話の受信はどの程度効果的ですか? 機内モードを使用した電話の受信はどの程度効果的ですか? Feb 20, 2024 am 10:07 AM

機内モードで電話をかけるとどうなるのですか? 携帯電話は、コミュニケーションツールであるだけでなく、娯楽、学習、仕事などの機能が集約された、人々の生活に欠かせないツールの一つとなっています。携帯電話機能の継続的なアップグレードと改善により、人々の携帯電話への依存度はますます高まっています。機内モードの登場により、人々は飛行中に携帯電話をより便利に使用できるようになりました。しかし、機内モードでの他人の通話が携帯電話やユーザーにどのような影響を与えるのかを心配する人もいます。この記事では、いくつかの側面から分析して議論します。初め

TikTokのコメント機能をオフにする方法は? TikTokのコメント機能をオフにするとどうなりますか? TikTokのコメント機能をオフにする方法は? TikTokのコメント機能をオフにするとどうなりますか? Mar 23, 2024 pm 06:20 PM

Douyin プラットフォームでは、ユーザーは自分の人生の瞬間を共有するだけでなく、他のユーザーと交流することもできます。コメント機能は、オンラインでの暴力や悪意のあるコメントなど、不快な経験を引き起こす可能性があります。では、TikTokのコメント機能をオフにするにはどうすればよいでしょうか? 1.Douyinのコメント機能をオフにする方法は? 1. Douyin APPにログインし、個人のホームページに入ります。 2. 右下隅の「I」をクリックして設定メニューに入ります。 3. 設定メニューで、「プライバシー設定」を見つけます。 4. [プライバシー設定] をクリックして、プライバシー設定インターフェイスに入ります。 5. プライバシー設定インターフェイスで、「コメント設定」を見つけます。 6. 「コメント設定」をクリックして、コメント設定インターフェースに入ります。 7. コメント設定インターフェイスで、「コメントを閉じる」オプションを見つけます。 8. [コメントを閉じる] オプションをクリックして、コメントを閉じることを確認します。

Java のファイル インクルードの脆弱性とその影響 Java のファイル インクルードの脆弱性とその影響 Aug 08, 2023 am 10:30 AM

Java は、さまざまなアプリケーションの開発に使用される一般的なプログラミング言語です。ただし、他のプログラミング言語と同様に、Java にもセキュリティ上の脆弱性とリスクがあります。一般的な脆弱性の 1 つは、ファイル インクルードの脆弱性 (FileInclusionVulnerability) です。この記事では、この脆弱性の原理、影響、および防止方法について説明します。ファイルインクルードの脆弱性とは、プログラム内に他のファイルが動的に導入または組み込まれることを指しますが、導入されたファイルは完全に検証および保護されていないため、

データ不足がモデルトレーニングに及ぼす影響 データ不足がモデルトレーニングに及ぼす影響 Oct 08, 2023 pm 06:17 PM

データ不足がモデル トレーニングに与える影響には、特定のコード サンプルが必要です。機械学習と人工知能の分野では、データはモデルをトレーニングするための中核要素の 1 つです。しかし、実際に私たちがよく直面する問題はデータ不足です。データ不足とは、トレーニング データの量が不足していること、またはアノテーション付きデータが不足していることを指し、この場合、モデルのトレーニングに一定の影響を及ぼします。データ不足の問題は、主に次の側面に反映されます。 過学習: トレーニング データの量が不十分な場合、モデルは過学習する傾向があります。過学習とは、モデルがトレーニング データに過剰に適応することを指します。

ハードドライブ上の不良セクタはどのような問題を引き起こしますか? ハードドライブ上の不良セクタはどのような問題を引き起こしますか? Feb 18, 2024 am 10:07 AM

ハードディスク上の不良セクタとは、ハードディスクの物理的な障害、つまりハードディスク上の記憶装置がデータを正常に読み書きできないことを指します。ハードドライブ上の不良セクタの影響は非常に大きく、データ損失、システムクラッシュ、ハードドライブパフォーマンスの低下につながる可能性があります。この記事では、ハードドライブの不良セクタの影響と関連する解決策について詳しく紹介します。まず、ハードドライブ上の不良セクタはデータ損失につながる可能性があります。ハードディスクのセクタに不良セクタがあると、そのセクタ上のデータを読み取ることができなくなり、ファイルが破損したりアクセスできなくなったりします。この状況は、不良セクタが存在するセクタに重要なファイルが保存されている場合に特に深刻です。

地雷カードはゲームに具体的にどのような影響を与えますか? 地雷カードはゲームに具体的にどのような影響を与えますか? Jan 03, 2024 am 09:05 AM

安さを求めてマイニング カードの購入を検討するユーザーもいるかもしれません。結局のところ、これらのカードは一流のグラフィックス カードです。しかし、一部のゲーマーは、マイニング カードがゲームのプレイに与える影響を心配しています。以下の詳細な紹介を見てみましょう。 。マイニング カードを使用してゲームをプレイする効果は次のとおりです。 1. マイニング カードの寿命は非常に短く、プレイしただけで役に立たなくなる可能性があるため、マイニング カードを使用してゲームをプレイする際の安定性は保証できません。 2. マイニング カードは基本的にオリジナル バージョンの去勢バージョンであり、長期にわたる磨耗により、あらゆる面でパフォーマンスが低下する可能性があります。 3. このように、ユーザーはゲームをプレイするときにゲームの効果をすべて表示できない場合があります。 4. さらに、グラフィックス カードの電子コンポーネントは事前に老化します。ゲームをプレイすることによってグラフィックス カードも消費されるため、消耗が大きくなり、ゲームへの影響が大きくなります。 5. 一般に、ゲームをプレイするにはマイニング カードを使用します。

シャーシの漏れはコンピュータにどのような影響を与えますか? シャーシの漏れはコンピュータにどのような影響を与えますか? Feb 22, 2024 pm 06:48 PM

シャーシの漏洩はコンピュータにどのような影響を及ぼしますか? 技術の継続的な進歩に伴い、コンピュータは徐々に人々の生活に不可欠なツールとなり、仕事、勉強、娯楽など、コンピュータの使用と切り離すことはできません。しかし、私たちはコンピュータの利便性を享受する一方で、そのセキュリティにも注意を払う必要があります。ケースの漏洩は潜在的な問題であり、時間内に対処しないとコンピューターとユーザーに重大な影響を与える可能性があります。まず第一に、シャーシの漏れはコンピュータのハードウェアに損傷を与えます。コンピューターのマザーボード、電源、内部回路、その他のコンポーネントはすべてシャーシ内にあります。

See all articles