MySQL スライディングオーダー問題の原理と解決の例分析

MySQL スライディングオーダー問題の原理と解決の例分析

この記事では、例を使用して、MySQL スライディング順序問題の原理と解決方法を説明します。ご参考までに、詳細は以下の通りです。

まず、MonthlyOrdersテーブルを作成し、次のコードに従ってデータをインポートします。

テーブル MonthlyOrders を作成します(
注文月 DATE、
順序番号 INT UNSIGNED,
主キー (ordermonth)
);

MonthlyOrders に INSERT INTO SELECT '2010-02-01',23; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-03-01',26; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-04-01',24; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-05-01',27; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-06-01',26; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-07-01',32; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-08-01',34; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-09-01',30; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-10-01',31; を追加します。
MonthlyOrders に INSERT INTO SELECT '2010-11-01',32; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2010-12-01',33; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-01-01',31; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-02-01',34; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-03-01',34; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-04-01',38; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-05-01',39; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-06-01',35; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-07-01',49; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-08-01',56; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-09-01',55; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-10-01',74; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-11-01',75; を挿入します。
MonthlyOrders に INSERT INTO SELECT '2011-12-01',14; を挿入します。

スライディングオーダー問題とは、前年度(四半期または月)の各月のスライディングオーダー数を返すこと、つまり、各 N 月について、N-11 から N 月までのオーダーの合計数を返すことを指します。ここでは、月の順序にギャップがないものと想定します。

次のSQLクエリを実行して、前年の各月のスライディングオーダーの合計数を返します。

選択
  DATE_FORMAT(a.ordermonth, '%Y%m') AS frommonth,
  DATE_FORMAT(b.ordermonth, '%Y%m') AS tomonth,
  SUM(c.ordernum) AS 注文
毎月の注文から
INNER JOIN 毎月の注文 b
  ON DATE_ADD(a.ordermonth, INTERVAL 11 MONTH) = b.ordermonth
INNER JOIN 毎月の注文 c
  c.ordermonth で、a.ordermonth と b.ordermonth の間
GROUP BY a.ordermonth、b.ordermonth;

実行結果は次のとおりです

クエリは最初に MonthlyOrders テーブルで自己結合を実行します。表 a は下限 (frommonth) として使用され、表 b は上限 (tomonth) として使用されます。接続の条件は次のとおりです。

DATE_ADD(a.ordermonth, INTERVAL 11 MONTH) = b.ordermonth

たとえば、表 a の 2010 年 2 月は 2011 年 1 月と一致します。

自己接続が完了したら、注文をカウントする必要があります。この時点で、範囲内の各月の注文数を取得するには、別の自己結合を実行する必要があります。接続の条件は

c.ordermonth は a.ordermonth と b.ordermonth の間です

上記の方法に基づいて、四半期ごとの受注状況を集計し、前年比の成長と比較するための基準として使用することもできます。

選択
  DATE_FORMAT(a.ordermonth, '%Y%m') AS frommonth,
  DATE_FORMAT(b.ordermonth, '%Y%m') AS tomonth,
  SUM(c.ordernum) AS 注文
毎月の注文から
INNER JOIN 毎月の注文 b
  ON DATE_ADD(a.ordermonth, INTERVAL 2 MONTH) = b.ordermonth
  AND MONTH(a.ordermonth) % 3 = 1
INNER JOIN 毎月の注文 c
  c.ordermonth で、a.ordermonth と b.ordermonth の間
GROUP BY a.ordermonth、b.ordermonth;

実行結果は次のとおりです

MySQL 関連のコンテンツに興味のある読者は、このサイトの次のトピックをチェックしてください: 「MySQL クエリ スキル」、「MySQL 共通関数の概要」、「MySQL ログ操作スキル」、「MySQL トランザクション操作スキルの概要」、「MySQL ストアド プロシージャ スキル」、および「MySQL データベース ロック関連スキルの概要」

この記事が皆様のMySQLデータベース設計に役立つことを願っています。

以下もご興味があるかもしれません:
  • MySQL の集計関数 count の使用法とパフォーマンスの最適化テクニック
  • MySQLでよく使われる集計関数の詳細な説明
  • MySql の集計関数に条件式を追加する方法
  • php+mysql オープンソース XNA 集計プログラムがダウンロード用にリリースされました
  • Mysql は非集計列を選択できません
  • MySQL クエリのソートとクエリ集計関数の使用法の分析
  • MySQL の単一テーブル クエリ操作例の詳細な説明 [構文、制約、グループ化、集計、フィルタリング、並べ替えなど]
  • MySQL 継続的集計の原理と使用法の分析
  • MySQLプロセス関数の一般的な使用例の分析
  • MySQLの累積集計原理と使用例の分析

<<:  CentOS8 - bash: 文字化けとその解決方法

>>:  jQueryはHTML要素の非表示と表示を実装します

推薦する

src 属性と href 属性の違い

src と href には違いがあり、混同される可能性があります。 src は現在の要素を置き換える...

デザイン理論: コンテンツプレゼンテーションのための 10 のヒント

<br /> テキスト、記号、リンクの3つの側面に焦点を当て、主に中国語で、個人的な執筆...

JavaScriptを使用してSMS認証コード間隔を送信する機能を実装する

多くのアプリやウェブサイトでは、ログインやアカウント登録の際にSMS認証コード1を送信する場所があり...

mysql 8.0.20 winx64.zip 圧縮版のインストールと設定方法のグラフィックチュートリアル

mysql 8.0.20 winx64.zip圧縮版のインストールチュートリアルは以下のように記録さ...

MySql ファジークエリ JSON キーワード取得ソリューションの例

目次序文オプション1:オプション2:オプション3:オプション4(最終的に採用されたオプション):要約...

MySQLはライブラリ内の主キーなしでテーブルインスタンスコードを素早く取得します

概要MySQL データベースで主キーのないテーブルを表示するための SQL ステートメントをいくつか...

js におけるイベントバブリングとイベントキャプチャの簡単な分析

目次01-イベントバブリング1.1- イベントバブリングの概要1.2-イベントバブリングの利用(イベ...

IISとAPACHEはHTTPSへのHTTPリダイレクトを実装しています

7 のMicrosoft の公式 Web サイトから HTTP Rewrite モジュールをダウンロ...

Linux 3.X/4.x/5.x でパゴダ パネルのパスワードを忘れた場合の解決方法

ssh に入り、次のコマンドを入力してパスワードをリセットします (コマンドの末尾の「testpas...

docker ベースの mariadb のインストール構成プロセスの分析

1. インストール dockerhub を通じてインストールする mariadb のバージョンを検索...

データベースアカウントのパスワード暗号化の詳細な説明と例

データベースアカウントのパスワード暗号化の詳細な説明と例データベースアカウントとパスワードはデータベ...

JavaScriptの無限ループを検出して防止する方法の詳細な説明

目次序文for文の無限ループを修正while文の無限ループを修正要約する序文Js デッド ループはど...

vue.js ルーターのネストされたルートの実例

目次序文Vue CLI での設定基本コードVueルーターの登場ネストされたルートの設定要約する序文V...

MySQLフィールド定義でnullを使用しない理由の分析

NULL が頻繁に使用されるのはなぜですか? (1)Javaのnull Java の NullPoi...

CSS3で線形グラデーションを実装するためのコードの詳細な説明

序文デモでは古いバージョンのブラウザのグラデーションが実装されています[IE9-]。 IE9 より前...