SQL GROUP BY 句と ORDER BY 句での名前の競合を回避するにはどうすればよいですか?
SQL GROUP BY 句と ORDER BY 句での名前の競合を避けるためのヒント
複数の列の組み合わせと並べ替えを伴う SQL クエリでは、出力列名とソース列名の間に名前の違いがある可能性があるため、GROUP BY
句と ORDER BY
句で使用される列名を慎重に検討する必要があります。 SQL言語の競合で。
たとえば、クエリの目的は、ハードウェア モデル (名前)、試行タイプ (タイプ)、およびバイナリ結果 (0 または 1 に単純化された結果) によってデータをグループ化することです。ただし、望ましい出力は、タイプとケースの一意の組み合わせを持つモデルごとに 1 行のみを表示することです。
この問題は、GROUP BY
式と CASE
式の両方でソース列名 result
を使用することで発生します。 SQL 標準では、この場合、GROUP BY
は result
をソース列名として解釈し、ORDER BY
を出力列名として解釈すると規定されています。
この競合を解決して期待どおりの出力を得るには、いくつかの方法があります:
-
列の別名を使用する :
CASE
式に別名を追加し、ソース列名とは異なるようにします。例:
... CASE WHEN attempt.result = 0 THEN 0 ELSE 1 END AS result1 ... GROUP BY model.name, attempt.type, result1 ...
- 位置参照を使用する: 数値を使用して、SELECT リスト内の列の位置を明示的に参照します。例:
... GROUP BY 1, 2, 3 ...
- には定数 が含まれています: 定数列 (日など) を
GROUP BY
に含める必要はありませんが、わかりやすくするために、結果に影響を与えることなく追加できます。
位置参照を使用して変更されたクエリは次のとおりです:
SELECT model.name , attempt.type , CASE WHEN attempt.result = 0 THEN 0 ELSE 1 END AS result , CURRENT_DATE - 1 AS day , count(*) AS ct FROM attempt JOIN prod_hw_id USING (hard_id) JOIN model USING (model_id) WHERE ts >= '2013-11-06 00:00:00' AND ts < '2013-11-07 00:00:00' GROUP BY 1, 2, 3 ORDER BY 1, 2, 3;
正しい列名を確保し、位置参照を使用することにより、クエリは期待どおりにデータを集計し、モデル、型、結果の一意の組み合わせごとに 1 行の結果のみを提供するようになりました。
以上がSQL GROUP BY 句と ORDER BY 句での名前の競合を回避するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック











Alter Tableステートメントを使用してMySQLのテーブルをどのように変更しますか?

Linuxでmysqlを実行します(phpmyAdminを使用してポッドマンコンテナを使用して/なし)

MACOSで複数のMySQLバージョンを実行する:ステップバイステップガイド

人気のあるMySQL GUIツール(MySQL Workbench、PhpMyAdminなど)は何ですか?

MySQL接続用のSSL/TLS暗号化を構成するにはどうすればよいですか?
