Beheben von Mehrdeutigkeiten in der WHERE-Klausel „user_id“ von MySQL
Beim Arbeiten mit mehreren Tabellen, die einen Spaltennamen teilen, kann es bei der Verwendung von MySQL zu Mehrdeutigkeiten kommen diese Spalte in einer WHERE-Klausel. Dies wird in der Fehlermeldung „user_id“ deutlich, in der die where-Klausel nicht eindeutig ist.
Betrachten Sie die Beispielabfrage:
SELECT user.*, user_info.* FROM user INNER JOIN user_info ON user.user_id = user_info.user_id WHERE user_id=1
In dieser Abfrage haben sowohl die Tabellen „user“ als auch „user_info“ eine Spalte „user_id“. Allerdings kann MySQL nicht bestimmen, welche „user_id“-Spalte in der WHERE-Klausel verwendet werden soll.
Auflösen der Mehrdeutigkeit
Um die Mehrdeutigkeit aufzulösen, müssen wir angeben, welche „user_id“ Spalte, die verwendet werden soll. Dies kann erreicht werden, indem der Tabellenname als Präfix zum Spaltennamen hinzugefügt wird, wie unten gezeigt:
... WHERE user.user_id=1
Durch Angabe von „user.user_id“ Wir erklären ausdrücklich, dass wir die Spalte „user_id“ aus der Tabelle „user“ in der WHERE-Klausel verwenden möchten.
Diese Klarstellung beseitigt die Mehrdeutigkeit und ermöglicht MySQL, die Abfrage auszuführen, ohne auf die Spalte „user_id“ in where zu stoßen Klausel ist ein mehrdeutiger Fehler. Denken Sie daran, immer das Tabellenpräfix anzugeben, wenn Sie in einer WHERE-Klausel auf mehrdeutige Spaltennamen verweisen, um dieses und ähnliche Probleme in Zukunft zu vermeiden.
Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.
Copyright© 2022 湘ICP备2022001581号-3