ホームページ > データベース > mysql チュートリアル > データベース内のすべてのテスト (A、B、C、D) に合格した車を見つけるにはどうすればよいですか?

データベース内のすべてのテスト (A、B、C、D) に合格した車を見つけるにはどうすればよいですか?

Mary-Kate Olsen
リリース: 2025-01-14 10:35:46
オリジナル
843 人が閲覧しました

How to Find Cars That Passed All Tests (A, B, C, D) in a Database?

リスト内のすべての項目に一致する行グループをフィルタリングします

2 つのテーブルがあるとします。

  • cars: 車とその対応するモデルをリストします。
  • passedtest: 固有の ID、車両名、テストの種類、日付など、各車両の合格したテストを記録します。

質問:

passedtest テーブルからすべてのテスト (A、B、C、D) に合格した車を特定するにはどうすればよいですか?

IN ステートメントの制限事項:

IN ステートメントを使用してテストのリストを含む行を照合すると、それらのテストのサブセットのみに合格した自動車が返される場合があります。

解決策: さまざまなテストの種類をグループ化してカウントします

このソリューションは COUNT() と HAVING 句を利用します:

<code class="language-sql">SELECT carname
FROM PassedTest
GROUP BY carname
HAVING COUNT(DISTINCT testtype) = 4;</code>
ログイン後にコピー

このクエリは、行を carname ごとにグループ化し、個別の testtype 値の数をカウントします。カウントが 4 の車は 4 つのテストすべてに合格したことになります。

追加のヒント:

結果セットに基づいて cars テーブルからデータを取得するには、次の拡張クエリを使用します:

<code class="language-sql">SELECT *
FROM cars
WHERE carname IN (
    SELECT carname
    FROM PassedTest
    GROUP BY carname
    HAVING COUNT(DISTINCT testtype) = 4
);</code>
ログイン後にコピー

以上がデータベース内のすべてのテスト (A、B、C、D) に合格した車を見つけるにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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