MySQL は SQL ステートメントの最新のレコードをクエリします (最適化)

MySQL は SQL ステートメントの最新のレコードをクエリします (最適化)

最悪の選択肢は、結果を時間順に並べ替えて最初のものを取ることです。

*から選択 
ここで、create_time<="2017-03-29 19:30:36" 
create_time 降順で並び替え
制限 1

この方法では、現時点で最新のレコードを取得できますが、クエリごとにテーブルを 1 回トラバースする必要があるため、100 万を超えるデータ ポイントを含むクエリでは時間がかかります。limit では、最初にすべての結果を取得してから最初の結果を取得するため、クエリで不要な時間とスペースが消費されます。また、最新のレコードをバッチで取得する必要がある場合 (たとえば、「注文テーブルにユーザー、注文時間、金額があり、すべてのユーザーの最新の注文レコードを一度にクエリする必要がある場合」)、各ユーザーのクエリでテーブル全体を 1 回トラバースする必要があります。データが大きい場合、時間は指数関数的に増加し、実用的ではありません。

中間戦略 - クエリをソートしてグループ化する

(から*を選択
  *から選択
  ここで、create_time<="2017-03-29 19:30:36" 
  create_time 降順で並び替え
) ユーザーIDでグループ化

その後、group by を使用すると、group by のパラメータ列でグループ化できますが、返される結果は 1 つだけであることがわかりました。注意深く観察すると、group by はグループ化後の最初のレコードを返すことがわかりました。デフォルトでは、時間はクエリ後に順番にソートされるため、現在の時間に最も近いものを取得するには、まず時間を逆順にソートする必要があります。

このクエリは実際には 2 つのクエリを実行します。時間は最初の方法よりもはるかに高速ですが、さらに最適化することができます。

最善の戦略は、max()メソッドをgroup byと組み合わせて使用​​することです。

*,max(create_time)をaから選択
ここで、create_time<="2017-03-29 19:30:36" 
ユーザーIDでグループ化

この文は、結果セットを user_id に従ってグループ化し、各グループ内で最大時間を持つレコードを取得すると理解できます。これにより、最新のレコードを一括でクエリすることが可能になり、テーブルを一度走査するだけで済むため、データ量が膨大な場合でも非常に短時間で結果を見つけることができます。

拡張機能:

資産機器テーブルができました: base_assets_turn

最新の資産管理者を照会する

注: 資産番号ASSETS_ID=254と仮定します。

次善の選択肢:

base_assets_turn から * を選択 
ASSETS_ID = 254の場合
create_time 降順で並び替え
制限 1

中間ポリシー:

選択 * から ( 選択 * から base_assets_turn 
ASSETS_ID = 254の場合
order by create_time desc) tt GROUP BY tt.ASSETS_ID;

最善の戦略:

では、最善の戦略はどのように書けばよいのでしょうか? ぜひメッセージをお寄せください!

上記は、編集者が提供した最新のレコードをクエリするためのMySQL SQL文(最適化)です。皆様のお役に立てれば幸いです。ご質問があれば、メッセージを残してください。

以下もご興味があるかもしれません:
  • MySQL で SQL クエリを最適化するための 30 の一般的な方法について簡単に説明します。
  • MYSQL クエリの効率を向上させる 10 の SQL ステートメント最適化テクニック
  • MySQL SQL 文を最適化するための 10 のヒント
  • MySQL SQL ステートメント分析とクエリ最適化の詳細な説明
  • MySQL テーブルの読み取り、書き込み、インデックス作成、その他の操作の SQL ステートメントの効率最適化の問題を分析します。
  • MySQL SQL文を最適化するためのヒント
  • MySQL の最適化: 高品質の SQL 文を書く方法
  • MySQL を最適化するための 19 の一般的かつ効果的な方法 (推奨!)

<<:  Linux でのプロセスデーモン スーパーバイザーのインストール、構成、および使用

>>:  ネイティブ Js で実装されたシンプルなシームレス スクロール カルーセルのサンプル コード

推薦する

MySQL ビッグデータ クエリ最適化エクスペリエンスの共有 (推奨)

本格的な MySQL 最適化! MySQL のデータ量が少ない場合は最適化は不要です。データ量が多い...

Dockerデータのバックアップとリカバリプロセスの詳細な説明

データのバックアップ操作は非常に簡単です。次のコマンドを実行します。 docker run --vo...

CSS で実現される HTML 背景色のグラデーション

エフェクトのスクリーンショット:実装コード:コードをコピーコードは次のとおりです。 <!DOC...

Dockerでmysqlのルートパスワードを変更する方法

最初のステップはmysqlコンテナを作成することです docker exec -it コンテナID ...

Linux に JDK1.8 をインストールするための詳細なチュートリアル

1. 設置前の清掃 rpm -qa | grep jdk rpm -qa | grep gcj yu...

4つのReactコンポーネントにおけるDOMスタイル設定の詳細な説明

1. インラインスタイル仮想DOMにインラインスタイルを追加するには、式を使用してスタイルオブジェク...

Mysql 5.7.17 をインストールした後、MySQL にログインするチュートリアル

mysql-5.7.17 のインストールについては記事の下部で紹介されているので、参考にしてください...

MySQL 5.7.15 のインストールと設定方法のグラフィック チュートリアル (Windows)

MySQL をインストールする必要があるため、インストール手順を以下のように記録します。 自分なり...

Tomcatアーキテクチャの原則をアーキテクチャ設計に分析する

目次1. 学習目標1.1. Tomcatアーキテクチャの設計と原則をマスターして社内スキルを向上させ...

フォーム要素の簡単な実装コードでは登録を例に挙げています

コード実装:コードをコピーコードは次のとおりです。 <!DOCTYPE html> &l...

Vueカスタムコンポーネントは双方向バインディングを実装します

シナリオ:一般的に使用される親コンポーネントと子コンポーネント間の相互作用方法は次のとおりです。親コ...

リモート接続を許可するようにMySQLを変更する方法

MySQLリモート接続の問題に関しては、会社で働いているときに誰かのコンピュータに保存されているMy...

マップタグパラメータの詳細な紹介と使用例

マップ タグはペアで表示する必要があります。 <map> ....</map>...

MySQL 面接の質問: ハッシュ インデックスの設定方法

B-Tree インデックスに加えて、MySQL は次のインデックスも提供します。ハッシュインデックス...

JS Canvas インターフェースとアニメーション効果

目次概要Canvas API: グラフィックスの描画パス線種矩形アーク文章グラデーションと画像の塗り...