ホームページ > データベース > mysql チュートリアル > MySQL の複数のフィールドで「SELECT DISTINCT」が失敗するのはなぜですか?

MySQL の複数のフィールドで「SELECT DISTINCT」が失敗するのはなぜですか?

Linda Hamilton
リリース: 2024-11-03 00:30:29
オリジナル
440 人が閲覧しました

Why Does

Mysql の最適化: "SELECT DISTINCT" の制限について

MYSQL では、"SELECT DISTINCT" 句を使用して、以下に基づいて重複行を削除します。指定された列の値。ただし、複数のフィールドを選択しようとするときに発生する可能性のある特定の制限があります。

問題:

「SELECT DISTINCT」の後にカンマ区切りのリストを使用する場合次の例に示すように、フィールドの数と別の "DISTINCT" 句を指定すると、エラーが発生します:

mysql_query("SELECT *, DISTINCT ticket_id FROM temp_tickets ORDER BY ticket_id")
ログイン後にコピー

説明:

個々のフィールドに適用される関数とは異なります。列の場合、「DISTINCT」は選択リスト内のすべての列に影響を与えるクエリ修飾子です。選択範囲内のすべての列が同じ値を持つ場合にのみ重複を削除します。

したがって、クエリは、カンマ区切りリストと「ticket_id」で指定された列を含む、すべての列に基づいて異なる行を出力しようとします。これにより、一意性を考慮する必要がある列が不明瞭になるため、あいまいさが生じます。

解決策:

すべてのフィールドを選択し、「ticket_id」に基づいて重複を削除するには、正しい構文は次のとおりです:

SELECT DISTINCT *, ticket_id FROM temp_tickets ORDER BY ticket_id
ログイン後にコピー

このクエリは、「ticket_id」を含むすべての列の結合値に基づいて重複を削除します。ただし、一意の「ticket_id」値ごとに最新のエントリのみが表示されます。すべての列の最新のエントリのみを取得するには、次のようにサブクエリを使用して、個別の「ticket_id」値ごとに最大の ticket_id を選択できます。

SELECT * FROM temp_tickets WHERE ticket_id IN (SELECT MAX(ticket_id) FROM temp_tickets GROUP BY ticket_id)
ログイン後にコピー

以上がMySQL の複数のフィールドで「SELECT DISTINCT」が失敗するのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート