Heim >Datenbank >MySQL-Tutorial >MySQL FIND_IN_SET() vs. IN(): Warum gibt IN() nur die erste Übereinstimmung mit durch Kommas getrennten IDs zurück?
FIND_IN_SET() vs. IN(): Den Unterschied in MySQL verstehen
Frage:
In MySQL haben wir zwei Tabellen: „orders“ und „company“. In der Spalte „attachedCompanyIDs“ in „orders“ wird eine durch Kommas getrennte Liste von IDs gespeichert, die auf Zeilen in „company“ verweisen. Bei der Abfrage von Firmennamen, die mit einer Bestellung verknüpft sind, mit FIND_IN_SET() erhalten wir die erwarteten Ergebnisse. Wenn Sie jedoch stattdessen IN() verwenden, wird nur das erste passende Unternehmen zurückgegeben. Warum passiert das?
Antwort:
Die Spalte „attachedCompanyIDs“ ist ein Skalarwert vom Typ VARCHAR. Bei Verwendung von IN() wandelt MySQL die Zeichenfolge in eine Ganzzahl um und schneidet sie beim ersten nicht numerischen Zeichen (d. h. einem Komma) ab. Das bedeutet, dass, wenn attachmentCompanyIDs mehrere Werte enthält, nur der erste für den IN-Vergleich berücksichtigt wird.
解决方法:
Abhängig von Ihrem spezifischen Szenario gibt es welche Mehrere Problemumgehungen für dieses Problem:
Zusätzliche Überlegungen:
Das obige ist der detaillierte Inhalt vonMySQL FIND_IN_SET() vs. IN(): Warum gibt IN() nur die erste Übereinstimmung mit durch Kommas getrennten IDs zurück?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!