MySql の集計関数に条件式を追加する方法

MySql の集計関数に条件式を追加する方法

MySQL のフィルタリングのタイミングは、集計関数で使用される where 条件と having 条件です。

集約前のフィルタ

クエリに集計関数とwhere条件が含まれている場合、例えば
t.id<999 の場合、t から max(cid) を選択します。
このとき、最初にフィルタリングが実行され、その後に集計が実行されます。まず、ID が 999 未満のレコードを除外し、次に最大の cid を見つけて返します。

集約後にフィルターを適用する

Having はグループ化時にグループ化結果をフィルタリングするために使用され、通常は集計関数が含まれます。

appからip,MAX(id)を選択
ipでグループ化
MAX(id)>=5 を持つ

まずグループ化し、次に集計し、集計結果が5以上になる結果セットをフィルタリングします。

両者の違い:

最初にが実行され、次に集計関数が実行されます。集計関数が実行された後に、Having が実行されます。

以下は補足です

テーブルにはステータス フィールド (1: 成功、2: 失敗など) が必要です。ここで、日付のグループ化を使用して、さまざまな状態にあるアイテムの数をカウントする必要があります。

まずサブクエリを書く

aa.logDate、aa.totalLogs を選択 
 、(dxp.dxp_handlermodel から count(1) を選択、aa.logDate=DATE_FORMAT( startTime, '%Y-%m-%d')、executeStatus=1) pendingLogs
 、(dxp.dxp_handlermodel から count(1) を選択、aa.logDate=DATE_FORMAT( startTime, '%Y-%m-%d')、executeStatus=2) successLogs
 、(dxp.dxp_handlermodel から count(1) を選択、aa.logDate=DATE_FORMAT( startTime, '%Y-%m-%d')、executeStatus=3) errorLogs
 、(dxp.dxp_handlermodel から count(1) を選択、aa.logDate=DATE_FORMAT( startTime, '%Y-%m-%d')、executeStatus=4) callbackErrorLogs
から
(
 選択
 DATE_FORMAT( a.startTime, '%Y-%m-%d') ログ日付、
 count(1) 合計ログ
 dxp.dxp_handlermodel から 
 DATE_FORMAT( a.startTime, '%Y-%m-%d') でグループ化 
)

実行が非常に遅いので、カウントする条件を追加できるかどうか疑問に思い、次のことがわかりました。

選択
DATE_FORMAT(開始時刻、'%Y-%m-%d') ログ日付、
 count(1) 合計ログ、
 count(if(executeStatus=1,true,null)) 保留中のログ、
 count(if(executeStatus=2,true,null)) 成功ログ、
 count(if(executeStatus=3,true,null)) エラーログ、
 count(if(executeStatus=4,true,null)) コールバックエラーログ
dxp.dxp_handlermodel から
DATE_FORMAT( startTime, '%Y-%m-%d') でグループ化

理解しやすく、実行効率が高い

SUMやその他の集計関数などの他の集計関数も使用できます。

実例:

profile_visit_log から count(if(create_date < '2017-01-01' かつ host_profile_id = '9294d2bf-f457-4fe5-9a36-e5f832310dc2',true,null)) を選択 
-- select count(if(create_date < '2017-01-01',true,null)) count from profile_visit_log where host_profile_id = '9294d2bf-f457-4fe5-9a36-e5f832310dc2' と同等

さて、この記事はこれで終わりです。今後とも123WORDPRESS.COMをよろしくお願いいたします。

以下もご興味があるかもしれません:
  • MySQL 集計関数のソート
  • MySQL グループ化クエリと集計関数
  • MySQL クエリのソートとクエリ集計関数の使用法の分析
  • MySQL の集計関数 count の使用法とパフォーマンスの最適化テクニック
  • MySQL の基本: グループ化関数、集計関数、グループ化クエリの詳細な説明

<<:  Vue ルーターにパラメータを渡すときにページを更新するとパラメータが失われる問題に対処する方法

>>:  IPとポートが接続可能かどうかを検出する方法

推薦する

CocosCreator で http と WebSocket を使用する方法

目次1. HTTPGET 2. HTTP POSTウェブソケット4. Egretのhttpとwebs...

MySQL シリーズ II マルチインスタンス構成

チュートリアルシリーズMySQL シリーズ: MySQL リレーショナル データベースの基本概念My...

スクロールバーがスペースを占有することで発生するバグを修正しました

背景このバグは滾動條占據空間ことで発生していました。いくつかの情報を確認して、ようやく解決しました。...

tomcat をインストールし、Linux で Web サイトを展開します (推奨)

jdk をインストールします: Oracle 公式ダウンロード https://www.oracl...

組み込み Linux で QT アプリケーションを再起動する簡単な方法 (QT4.8 qws ベース)

アプリケーション ソフトウェアには通常、次のようなビジネス要件があります。新しいバージョンの APP...

Vue Notepadの例の詳細な説明

この記事の例では、メモ帳機能を実装するためのVueの具体的なコードを参考までに共有しています。具体的...

MySQLに画像を保存する方法

1 はじめにデータベースを設計する場合、画像や音声ファイルをデータベースに挿入することは避けられませ...

Linux で so または実行可能プログラムの依存ライブラリを表示します

Linux で実行可能プログラムまたは so の依存ライブラリを表示します。 Linux の実行可能...

JavaScriptの厳密モードが8進数をサポートしていない問題の説明

JavaScript厳密モードが 8 進数をサポートしていないという問題に関して、まず、 Java...

Vue でのルータービューコンポーネントの使用に関する詳細な説明

Vue プロジェクトを開発する場合、さまざまなコンポーネント ページを表示するために切り替えることが...

知っておくべきHTML最適化テクニック

Web ページのパフォーマンスを向上させるために、多くの開発者は、JavaScript、画像の最適化...

CSS3はグラフィックの落下アニメーション効果を実現します

まずは効果を確認実装コード <div class="box box1"&g...

Vue プロジェクトで mock.js を使用するための完全な手順

Vue プロジェクトで mock.js を使用する開発ツールの選択: Vscode 1. コマンドラ...

JavaScript データ プロキシとイベントの詳細な分析

目次データブローカーとイベントObject.defineProperty メソッドのレビューデータブ...

Vueは動的クエリルール生成コンポーネントを実装します

1. 動的クエリルール動的クエリルールは、おおよそ次の図のようになります。ユーザのカスタマイズに応じ...