最悪の選択肢は、結果を時間順に並べ替えて最初のものを取ることです。 *から選択 ここで、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文(最適化)です。皆様のお役に立てれば幸いです。ご質問があれば、メッセージを残してください。 以下もご興味があるかもしれません:
|
<<: Linux でのプロセスデーモン スーパーバイザーのインストール、構成、および使用
>>: ネイティブ Js で実装されたシンプルなシームレス スクロール カルーセルのサンプル コード
目次セーフモード設定テスト1. where句なしで更新および削除する2. 非インデックスキーの削除3...
(P4) Web 標準は一連の標準で構成されています。中心となる概念は、Web ページの構造、スタイ...
以下は、Flex レイアウトを使用した棒グラフです。 HTML: <div class=&qu...
背景画像でも、ページ上のテキストサイズでも、1 ピクセルの違いは非常に明白です。そして、私は学生時代...
目次1. スコープはさまざまな方法で表現されます2. 変動昇進と非昇進の違い3. 一時的なデッドゾー...
目次1. コンポーネント化とは何ですか? 2. 基本的な使い方序文:場合によっては、HTML 構造化...
以下は、HTML で正規表現を使用してテーブルをチェックするサンプル コードです。具体的なコードの内...
具体的なコードは次のとおりです。 <スタイル> #トーストローダーフルスクリーン{ 高さ...
目次iview-admin2.0 組み込み権限管理権限に基づいてコンポーネントの表示を制御するカスタ...
CSS によるテキストの切り捨てテキストを自動的に切り捨てるスタイル コードを実装するには、次のコー...
Centos7では、/etc/rc.d/rc.localファイルの権限が削減されており、実行権限があ...
mysqladmin は管理と操作を行う公式の mysql クライアント プログラムです。MySQL...
1. トップレベルの使用法1. cnpmをインストールする npm i -g cnpm --regi...
Vue プロジェクトで div ホイールのズームインとズームアウト、ドラッグ効果、キャンバス効果に似...
HTML タグには、ページのタイトルを処理するための特別なタグがあります。これらは h1、h2、h3...