Heim > Datenbank > MySQL-Tutorial > So lösen Sie das Duplizierungsproblem in MySQL mithilfe einer Left-Join-Verbindung

So lösen Sie das Duplizierungsproblem in MySQL mithilfe einer Left-Join-Verbindung

王林
Freigeben: 2023-06-02 13:13:41
nach vorne
2907 Leute haben es durchsucht

    Duplikate treten auf, wenn MySQL eine Left-Join-Verbindung verwendet.

    Problembeschreibung: Wenn Sie eine Join-Abfrage verwenden, z. B. Tabelle A als Haupttabelle und Left-Join-Tabelle B verwenden, erwarten wir, wie viele Datensätze darin enthalten sind Tabelle A, Abfrage Das Ergebnis wird so viele Datensätze wie vorhanden sein, aber es kann ein Ergebnis wie dieses geben, das heißt, die Gesamtzahl der abgefragten Datensätze ist größer als die Gesamtzahl der Datensätze in Tabelle A, und einige Spalten werden wiederholt Wenn die Abfrageergebnisse angezeigt werden, wird einfach das kartesische Produkt erstellt.

    Beispiel für ein Problem

    Tabelle A ist die Benutzertabelle (Benutzer) und die Felder sind:

    ID-Name Benutzer-ID
    1 aaaa 10001

    2 bbbb 10002
    3 ccccc 10003

    Tabelle B ist der erste Typ von Produkttabelle (Produkt), die Felder sind:

    ID Titelzeit Benutzer-ID
    1 Titel 1 2014-01-01 10002

    2 Titel 2 2014-01-01 10002
    3 Titel 3 2014-01-01 10001
    4 Titel 4 2018-03-20 10002
    5 Titel 5 2018-03-20 10003

    Als wir zu diesem Zeitpunkt die folgende SQL zur Ausführung verwendeten, stellten wir fest, dass
    selecct * from user left join product on user.userid=product.userid;
    Nach dem Login kopieren

    So lösen Sie das Duplizierungsproblem in MySQL mithilfe einer Left-Join-VerbindungDas Ausführungsergebnis höher war als die Gesamtsumme Anzahl der Datensätze in der Benutzertabelle

    Problem gelöst

    Tatsächlich kann dieses Problem von einem anspruchsvollen Auge auf einen Blick erkannt werden, da das linke Join-Schlüsselwort in der Produkttabelle nicht eindeutig ist, sodass dieser Teil der nicht eindeutigen Daten ist erzeugt ein kartesisches Produkt, was zu mehr Ausführungsergebnissen als erwartet führt.

    Die Lösung besteht darin, eindeutige Schlüssel zu verwenden, um Verknüpfungsabfragen zuzuordnen und durchzuführen.

    Wenn MySQL Left Join verwendet, weisen die Daten in der rechten Tabelle doppelte Daten auf.

    Das Schlüsselwort LEFT JOIN gibt alle Zeilen aus der linken Tabelle (Tabellenname1) zurück. Auch wenn es in der richtigen Tabelle (table_name2) keine passenden Zeilen gibt. Zu diesem Zeitpunkt gibt es kein Problem, wenn die rechte Tabelle (table_name2) keine Daten oder nur ein Datenelement enthält, nachdem sie mit dem Schlüsselwort on gefiltert wurde.

    Was ich sagen möchte, ist, was zu tun ist, wenn in der richtigen Tabelle (Tabellenname2) doppelte Daten (vollständige Duplizierung im Geschäft) vorhanden sind.

    Wenn nach dem Filtern mit dem Schlüsselwort „on“ doppelte Daten in der rechten Tabelle (Tabellenname2) angezeigt werden, sind die zu diesem Zeitpunkt gefundenen Daten: Daten der rechten Tabelle * doppelte Daten + andere bedingte Daten in der rechten Tabelle und die Anzahl der Daten wir brauchen anders.

    Meine Lösung besteht darin, zuerst die richtige Tabelle (table_name2) gemäß der Filterfeldgruppierung abzufragen, dieselben Daten herauszufiltern und dann das Ergebnis als die richtige Tabelle für die Zuordnung zu behandeln

    前面脑补 
    LEFT JOIN (SELECT MODEL_CODE,MODEL_NAME from tm_model GROUP BY MODEL_CODE) tm on tav.model_code = tm.MODEL_CODE 
    后面脑补
    Nach dem Login kopieren

    Das obige ist der detaillierte Inhalt vonSo lösen Sie das Duplizierungsproblem in MySQL mithilfe einer Left-Join-Verbindung. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

    Verwandte Etiketten:
    Quelle:yisu.com
    Erklärung dieser Website
    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
    Beliebte Tutorials
    Mehr>
    Neueste Downloads
    Mehr>
    Web-Effekte
    Quellcode der Website
    Website-Materialien
    Frontend-Vorlage