Mysql での 4 つの挿入方法の効率比較
この記事では、項目ごとの挿入、トランザクションベースのバッチ挿入、一度に複数のデータセットを挿入する単一ステートメント、およびインポートの 4 つの方法の比較を含む、Mysql でのいくつかの挿入方法の効率の比較を例で紹介します。この記事では、サンプルコードを通じてそれを詳しく紹介しています。必要な場合は、一緒に見てください。
はじめに
最近、仕事の都合でMysqlに1000万ほどの大量のデータを入れる必要があり、目視検査の方が手間がかかります。したがって、現在は、どの方法でデータを挿入するのがより速く、より効率的であるかをテストするようなものです。
以下では、各メソッドの異なるデータ量での挿入効率をテストします。
テスト データベースの基本と操作は次のとおりです:
mysql> create database test; Query OK, 1 row affected (0.02 sec) mysql> use test; Database changed mysql> create table mytable(id int primary key auto_increment ,value varchar(50)); Query OK, 0 rows affected (0.35 sec) mysql> desc mytable; +-------+-------------+------+-----+---------+----------------+ | Field | Type | Null | Key | Default | Extra | +-------+-------------+------+-----+---------+----------------+ | id | int(11) | NO | PRI | NULL | auto_increment | | value | varchar(50) | YES | | NULL | | +-------+-------------+------+-----+---------+----------------+ 2 rows in set (0.02 sec)
テストを容易にするために、ここでは 2 つのフィールドを含むテーブルが構築されます。1 つは自動インクリメントされる ID、もう 1 つはコンテンツを表す文字列です。
テストする場合は、実験のたびにmysql> truncate mytable
既存のテーブルをクリアする必要があります。
方法1: 1つずつ挿入
テストコード:(途中に1000個のinsert文があります。vimでコピー&ペーストした方が便利です。書いた後、a.sqlに保存し、 mysql プロンプト .sql にソース a と入力します)
set @start=(select current_timestamp(6)); insert into mytable values(null,"value"); ...... insert into mytable values(null,"value"); set @end=(select current_timestamp(6)); select @start; select @end;
出力結果:
Query OK, 1 row affected (0.03 sec) ...... Query OK, 1 row affected (0.03 sec) Query OK, 0 rows affected (0.00 sec) +----------------------------+ | @start | +----------------------------+ | 2016-05-05 23:06:51.267029 | +----------------------------+ 1 row in set (0.00 sec) +----------------------------+ | @end | +----------------------------+ | 2016-05-05 23:07:22.831889 | +----------------------------+ 1 row in set (0.00 sec)
実際、ほぼすべてのステートメントに同じ時間がかかり、基本的には 30 ミリ秒かかります。
この方法では、1000wのデータには87時間かかります。
データ量が大きい場合は、この方法は絶対にお勧めしません。
方法 2: トランザクションベースのバッチ挿入
実際には、1 つのトランザクションに非常に多くのクエリを入れることになります。実際、メソッド 1 のすべてのステートメントはトランザクションを開くため、特に遅くなります。
テストコード: (基本的に方法1と似ていますが、主に2行追加しています。高速なため、ここではさまざまなデータ量をテストします)
set @start=(select current_timestamp(6)); start transaction; insert into mytable values(null,"value"); ...... insert into mytable values(null,"value"); commit; set @end=(select current_timestamp(6)); select @start; select @end;
テスト結果:
数据量 时间(s) 1k 0.1458 1w 1.0793 10w 5.546006 100w 38.930997
基本的に対数時間であることがわかります、効率は依然として比較的高いです。
方法3: 1つのステートメントで一度に複数のデータセットを挿入する
一度に複数の値を挿入する挿入です。
テストコード:
insert into mytable values (null,"value"), (null,"value"), ...... (null,"value");
テスト結果:
数据量 时间(s) 1k 0.15 1w 0.80 10w 2.14 100w *
これも対数時間のようで、方法2より若干速いです。ただし、問題は、単一の SQL ステートメントにはバッファ サイズ制限があることです。設定を変更してサイズを大きくすることはできますが、大きすぎることはできません。そのため、大量のデータを挿入する場合には使用できません。
方法 4: データ ファイルをインポートする
数値データをデータ ファイルに書き込み、直接インポートします (前のセクションを参照)。
データファイル(a.dat):
null value null value ..... null value null value
テストコード:
mysql> load data local infile "a.dat" into table mytable;
テスト結果:
数据量 时间(s) 1k 0.13 1w 0.75 10w 1.97 100w 6.75 1000w 58.18
最速タイムを出したのは彼です。 。 。 。
以上がMysql での 4 つの挿入方法の効率比較の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









MySQLデータベースでは、ユーザーとデータベースの関係は、アクセス許可と表によって定義されます。ユーザーには、データベースにアクセスするためのユーザー名とパスワードがあります。許可は助成金コマンドを通じて付与され、テーブルはCreate Tableコマンドによって作成されます。ユーザーとデータベースの関係を確立するには、データベースを作成し、ユーザーを作成してから許可を付与する必要があります。

データ統合の簡素化:AmazonrdsmysqlとRedshiftのゼロETL統合効率的なデータ統合は、データ駆動型組織の中心にあります。従来のETL(抽出、変換、負荷)プロセスは、特にデータベース(AmazonrdsmysQlなど)をデータウェアハウス(Redshiftなど)と統合する場合、複雑で時間がかかります。ただし、AWSは、この状況を完全に変えたゼロETL統合ソリューションを提供し、RDSMYSQLからRedshiftへのデータ移行のための簡略化されたほぼリアルタイムソリューションを提供します。この記事では、RDSMysQl Zero ETLのRedshiftとの統合に飛び込み、それがどのように機能するか、それがデータエンジニアと開発者にもたらす利点を説明します。

MySQLは、インストールが簡単で、強力で管理しやすいため、初心者に適しています。 1.さまざまなオペレーティングシステムに適した、単純なインストールと構成。 2。データベースとテーブルの作成、挿入、クエリ、更新、削除などの基本操作をサポートします。 3.参加オペレーションやサブクエリなどの高度な機能を提供します。 4.インデックス、クエリの最適化、テーブルパーティション化により、パフォーマンスを改善できます。 5。データのセキュリティと一貫性を確保するために、バックアップ、リカバリ、セキュリティ対策をサポートします。

MySQLのユーザー名とパスワードを入力するには:1。ユーザー名とパスワードを決定します。 2。データベースに接続します。 3.ユーザー名とパスワードを使用して、クエリとコマンドを実行します。

1.正しいインデックスを使用して、データの量を削減してデータ検索をスピードアップしました。テーブルの列を複数回検索する場合は、その列のインデックスを作成します。あなたまたはあなたのアプリが基準に従って複数の列からのデータが必要な場合、複合インデックス2を作成します2。選択した列のみを避けます。必要な列のすべてを選択すると、より多くのサーバーメモリを使用する場合にのみサーバーが遅くなり、たとえばテーブルにはcreated_atやupdated_atやupdated_atなどの列が含まれます。

NAVICAT自体はデータベースパスワードを保存せず、暗号化されたパスワードのみを取得できます。解決策:1。パスワードマネージャーを確認します。 2。NAVICATの「パスワードを記憶する」機能を確認します。 3.データベースパスワードをリセットします。 4.データベース管理者に連絡してください。

次のコマンドでmysqlデータベースを表示します。サーバーに接続します:mysql -u username -pパスワードrun showデータベース。すべての既存のデータベースを取得するコマンド[データベース]を選択します。データベース名を使用します。テーブルを表示:表を表示します。テーブル構造を表示:テーブル名を説明してください。データを表示:[テーブル名]から[ *]を選択します。

データベース酸属性の詳細な説明酸属性は、データベーストランザクションの信頼性と一貫性を確保するための一連のルールです。データベースシステムがトランザクションを処理する方法を定義し、システムのクラッシュ、停電、または複数のユーザーの同時アクセスの場合でも、データの整合性と精度を確保します。酸属性の概要原子性:トランザクションは不可分な単位と見なされます。どの部分も失敗し、トランザクション全体がロールバックされ、データベースは変更を保持しません。たとえば、銀行の譲渡が1つのアカウントから控除されているが別のアカウントに増加しない場合、操作全体が取り消されます。 TRANSACTION; updateaccountssetbalance = balance-100wh
