MySQL における制限関数と合計関数の混在使用の問題の詳細な説明

MySQL における制限関数と合計関数の混在使用の問題の詳細な説明

序文

今日、注文データを同期した後、同僚は、合計注文金額とデータソースの合計金額に差があったため、LIMIT 関数と SUM() 関数を使用して現在のページの合計金額を計算し、特定の注文の合計金額を他の当事者と比較することを選択しました。しかし、計算された金額はページ化された注文の合計金額ではなく、すべての注文の合計金額であることがわかりました。

データベースのバージョンは MySQL 5.7 です。以下では、例を使用して発生した問題を確認します。

問題のレビュー

このレビューでは、非常に単純な注文テーブルを例として使用します。

データ準備

注文テーブルの作成ステートメントは以下のとおりです(ここでは面倒なので自動増分 ID を使用します。実際の開発では自動増分 ID を注文 ID として使用することは推奨されません)

テーブル「order」を作成します(
 `id` int(11) NOT NULL AUTO_INCREMENT COMMENT '注文ID',
 `amount` 小数点(10,2) NOT NULL COMMENT '注文金額',
 主キー (`id`)
)ENGINE=InnoDB デフォルト文字セット=utf8mb4;

100の金額を挿入するSQLは次のようになります(10回実行)

`order`(`amount`) VALUES (100) に INSERT します。

したがって、合計金額は 10 * 100 = 1000 になります。

問題のあるSQL

limitを使用してページ内のデータを照会し、sum()関数を使用して現在のページの合計量を計算します。

選択 
  SUM(`金額`)
から
  「注文」
`id` で並べ替え
制限5;

前述のように、期待される結果は 5*100=500 ですが、実際の結果は 1000.00 です (小数点はデータ型によるものです)。

トラブルシューティング

実際、SELECT ステートメントの実行順序をある程度理解していれば、返される結果がすべての注文の合計金額である理由をすぐに判断できます。次に、問題のある SQL の実行シーケンスに基づいて問題を分析します。

  1. FROM: 最初に FROM 句が実行され、クエリが注文テーブルであることが決定されます。
  2. SELECT: SELECT 句は 2 番目に実行される句であり、この時点で SUM() 関数も実行されます。
  3. ORDER BY: ORDER BY 句は 3 番目に実行される句であり、結果は 1 つだけ、つまり注文の合計金額になります。
  4. LIMIT: LIMIT句は最後に実行され、この時点で結果セットには結果が1つだけあります(注文の合計金額)

補足コンテンツ

SELECT文の実行順序は次のとおりです。

  1. <左テーブル> から
  2. ON <結合条件>
  3. <結合タイプ> JOIN <右テーブル>
  4. WHERE <where_condition>
  5. GROUP BY <group_by_list>
  6. HAVING <having_condition>
  7. 選択
  8. DISTINCT <選択リスト>
  9. ORDER BY <order_by_condition>
  10. LIMIT <制限数>

解決

ページング データをカウントする必要がある場合 (SUM() 関数に加えて、一般的な COUNT()、AVG()、MAX()、および MIN() 関数にもこの問題があります)、サブクエリを使用して処理することを選択できます (PS: ここではメモリ計算は考慮されておらず、目的はデータベースを使用してこの問題を解決することです)。上記の問題の解決策は次のとおりです。

選択 
  SUM(o.金額)
から
  (選択 
    「金額」
  から
    「注文」
  `id` で並べ替え
  制限5) AS o;

操作の戻り値は 500.00 です。

要約する

以上がこの記事の全内容です。この記事の内容が皆様の勉強や仕事に何らかの参考学習価値をもたらすことを願います。123WORDPRESS.COM をご愛顧いただき、誠にありがとうございます。

以下もご興味があるかもしれません:
  • MySQL クエリの最適化: LIMIT 1 はテーブル全体のスキャンを回避し、クエリの効率を向上させます
  • 制限を使用すると、MySQL のページングがどんどん遅くなるのはなぜですか?
  • MySQL 最適化 query_cache_limit パラメータの説明
  • MySQLのorder byとlimitを混在させる際の落とし穴の詳細な説明
  • MySQL ページングの制限パラメータの簡単な例
  • 大きなオフセットによる MySQL 制限ページングが遅い理由と最適化ソリューション
  • MySQL のソートとページング (order by と limit) と既存の落とし穴
  • MySQLの制限を使用して大規模なページングの問題を解決する方法
  • MySQL Limitクエリのパフォーマンスを向上させる方法
  • MySQL Limitパフォーマンス最適化とページングデータパフォーマンス最適化の詳細な説明
  • MySQL の制限ページング最適化ソリューションの実装に関する簡単な説明
  • MySQL のクエリパフォーマンスに対する制限の影響

<<:  Linux を使用して時間指定ファイルが占有するディスク容量を計算する方法

>>:  Vueのドラッグスクリーンショット機能を実装する簡単な方法

推薦する

MySQL テーブル内の重複データを検索して削除する方法の概要

時々、データベース テーブルに重複したデータが大量に保存されます。これらの重複データはリソースを浪費...

MySQL ステートメントに一重引用符またはバックスラッシュを含む値を挿入する方法

序文この記事では主に、シングルクォートやバックスラッシュを含む値を挿入するMySQLステートメントに...

Vue ElementUI フォームのフォーム検証

フォーム検証は、フロントエンド開発プロセスで最もよく使用される機能の 1 つです。私の個人的な仕事経...

HTMLはマウスをホバーしたときにテキストを表示するためにtitle属性を使用します。

コードをコピーコードは次のとおりです。 <a href=# title="ここに表示...

SQL IDENTITY_INSERT ケーススタディ

一般的に、データ テーブル内の列を ID 列として設定すると、ID 列の表示値を手動で ID 列に挿...

Docker インストール Nginx チュートリアル 実装図

Nginx をインストールして試してみましょう。画像はクラスであり、コンテナはオブジェクトであること...

HTML テーブル境界制御実装コード

一般的に、テーブルを使用する場合は、常に <table border="1"...

Vue echarts は棒グラフの動的な表示を実現します

この記事では、棒グラフの動的な表示を実現するためのvue echartsの具体的なコードを参考までに...

入力テキスト ボックスと画像検証コードの位置合わせの問題 (画像は常に入力より 1 つ上になります)

Web ページ制作では、input と img が同じ行に配置されることが多く、img タグが常に ...

show processlist コマンドによる MySQL パフォーマンス検査の説明

show processlist コマンドは非常に便利です。MySQL の実行が 50% 以上になる...

CSS と HTML とフロントエンド テクノロジーのレイヤー図

JavascriptとDOMの関係は非常に曖昧で、CSSやHTMLのフロントエンド技術層も理解してい...

Linux で NFS のワンクリック展開を実装する方法

サーバー情報管理サーバー: m01 172.16.1.61サーバー: nfs01 172.16.1....

史上最もシンプルな MySQL データのバックアップと復元のチュートリアル (パート 2) (パート 36)

データのバックアップと復元パート2は次のとおりです基本的な概念:バックアップ、現在のデータまたはレコ...

Web ベースの電子メール コンテンツの HTML フォーマット標準の概要

1. ページ要件1) 標準のヘッダーとフッターを使用するXML/HTML コードコンテンツをクリップ...

Linux での MySQL 5.7.19 のインストールに関する問題の概要

初めて仮想マシンに MySQL をインストールしたとき、多くの問題が発生しました。ここでそれらを書き...