序文インデックスを追加した場合と追加しなかった場合の違いを反映するには、数百万のデータを使用する必要があります。ただし、数百万のデータを 1 つずつテーブルに追加すると、非常に面倒で面倒です。ここでは、ストアド プロシージャを使用してデータをすばやく追加しますが、これには約 4 時間かかります。 テーブル `t_sales` を作成します ( `id` int(11) NOT NULL AUTO_INCREMENT, `username` varchar(32) COLLATE utf8_bin DEFAULT NULL COMMENT 'ユーザー名', `password` varchar(64) COLLATE utf8_bin DEFAULT NULL COMMENT 'パスワードMD5ストレージ', `register_time` タイムスタンプ NULL デフォルト NULL コメント '登録時間', `type` int(1) DEFAULT NULL COMMENT 'ユーザータイプ 1,2,3,4 ランダム', 主キー (`id`)、 キー `idx_username` (`username`) BTREE の使用 ) 次に、データをバッチで追加するためのストアド プロシージャを作成します。
プロシージャ salesAdd() を作成する 始める i int をデフォルト 11 として宣言します。 i <= 4000000 の間 blog.t_salesに挿入 (`username`,`password`,`register_time`,type) 値 (concat("jack",i),MD5(concat("psswe",i)),from_unixtime(unix_timestamp(now()) - floor(rand() * 800000)),floor(1 + rand() * 4)); i = i + 1 と設定します。 終了しながら; 終わり 次にストアドプロシージャを呼び出します salesAdd() を呼び出す 改良版ストアド プロシージャを使用してデータを追加する方が、データを 1 つずつ追加するよりも便利で高速ですが、数百万のデータを追加するには数時間かかります。その後、インターネットで多くの情報を見つけ、MySQL がステートメントを実行するたびに自動的にコミットすることを発見しました。この操作は非常に時間がかかるため、自動コミットを追加および削除しました。 AUTOCOMMIT を 0 に設定します。 プロシージャ salesAdd() を作成する 始める i int をデフォルトで 1 と宣言します。 自動コミットを 0 に設定します。 i <= 4000000 の間 blog.t_salesに挿入 (`username`,`password`,`register_time`,type) 値 (concat("jack",i),MD5(concat("psswe",i)),from_unixtime(unix_timestamp(now()) - floor(rand() * 800000)),floor(1 + rand() * 4)); i = i + 1 と設定します。 終了しながら; 自動コミットを 1 に設定します。 終わり 実行時間は387秒、つまり約6分で、その半分の時間はmd5と乱数の計算に使われます。
これで、MySQL のストアド プロシージャを使用して数百万のデータをすばやく追加する方法に関するこの記事は終了です。MySQL で数百万のデータを追加する方法の詳細については、123WORDPRESS.COM の以前の記事を検索するか、次の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。 以下もご興味があるかもしれません:
|
<<: docker compose を使ってワンクリックで分散構成センター Apollo を展開するプロセスの詳細な説明
現在の日付 + 時刻 (日付 + 時刻) を取得する関数: now() mysql> now(...
目次導入説明書実際の経験長所と短所総括する導入mysqlpump は mysqldump の派生です...
目次1. クロージャを使用する2. ES6クラスを使用する3. ES2020提案を使用する4. We...
Mac で開発されたプロジェクトがあり、パッケージ npm i がインストールされており、すべて正常...
この記事には、細かい点は一切なく、カラーマッチングのテクニックをシェアするだけです。とてもシンプルで...
目次導入MySQL 高可用性マスター 1 つとバックアップ 1 つ: MySQL マスター スレーブ...
グリッドレイアウト親要素に追加された属性グリッドテンプレートの列/グリッドテンプレートの行要素の行ま...
この記事では、パズル効果を実現するためのネイティブjsの具体的なコードを参考までに共有します。具体的...
Navicat を使用して IP 経由で直接接続すると、次のようなさまざまなエラーが報告されます: ...
データベースバージョン: mysql> select version(); +--------...
出典: https://medium.com/better-programming、著者: Fere...
目次導入クッキークッキーとはクッキー生成方法クッキーの適用シナリオクッキーのデメリット回避策ローカル...
序文ターミナルを使用してデータベースまたはテーブルを作成するたびに、文字セットが latin1 であ...
目次タグ付きユニオン型を使用した支払い方法の構築タグ付きユニオン型を使用した Redux アクション...
tbody 要素は、thead 要素および tfoot 要素と組み合わせて使用する必要があります...