Heim >Datenbank >MySQL-Tutorial >Wie wähle ich Zeilen mit doppelten IDs, aber unterschiedlichen Werten in SQL aus?

Wie wähle ich Zeilen mit doppelten IDs, aber unterschiedlichen Werten in SQL aus?

Barbara Streisand
Barbara StreisandOriginal
2024-12-27 01:19:09661Durchsuche

How to Select Rows with Duplicate IDs but Different Values in SQL?

Auswählen von Zeilen mit doppelten IDs und unterschiedlichen Werten

Sie stehen vor einer Datenverwaltungsherausforderung, bei der Sie über eine Tabelle mit IDs (ARIDNR) und verfügen entsprechende Werte (LIEFNR). Ihr Ziel besteht darin, alle Zeilen mit doppelten IDs, aber unterschiedlichen Werten in der Spalte LIEFNR zu identifizieren und auszuwählen.

Lösung:

Um diese Aufgabe zu erfüllen, verwenden Sie die folgende SQL Abfrage:

SELECT *
FROM Table
WHERE ARIDNR IN (
    SELECT ARIDNR
    FROM Table
    GROUP BY ARIDNR
    HAVING COUNT(distinct LIEFNR) > 1
)

Erklärung:

  • Die äußere Abfrage (SELECT *) ruft alle Spalten für Zeilen ab, die die angegebene Bedingung erfüllen.
  • Die innere Abfrage (SELECT ARIDNR) wählt die eindeutigen ARIDNR-Werte aus.
  • Die GROUP BY-Klausel gruppiert die Zeilen durch die ARIDNR-Spalte.
  • Die HAVING-Klausel filtert die Ergebnisse, um nur Gruppen mit mehr als einem eindeutigen LIEFNR-Wert einzuschließen.

Diese Abfrage isoliert effektiv Zeilen mit doppelten ARIDNRs und unterschiedlichen LIEFNR-Werten . Bei der Ausführung wird die gewünschte Ausgabe erzeugt:

+------+------+
| ARIDNR | LIEFNR |
+------+------+
| 1     | A     |
+------+------+
| 1     | B     |
+------+------+
| 2     | A     |
+------+------+
| 2     | B     |
+------+------+

Diese Lösung geht effizient auf Ihre Anforderungen ein und bietet eine zuverlässige Methode zum Identifizieren und Auswählen von Zeilen mit den angegebenen Kriterien.

Das obige ist der detaillierte Inhalt vonWie wähle ich Zeilen mit doppelten IDs, aber unterschiedlichen Werten in SQL aus?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn