![]() |
Datenbank: MySQL • Version: 5.0.19-nt • Zugriff über: PHP
Query läuft bei MySQL4(.1), bei MySQL5 aber nicht
Hi @all,
ich habe ein kleines Problem mit einem Query, das ich in einem phpBB-MOD verwende. Und zwar hat mir jemand eine Fehlermeldung geschickt, die ich auf MySQL4 und MySQL4.1 nicht reproduzieren kann, mit MySQL5 tritt der Fehler jedoch auf. Kann mir jemand sagen, woran das liegt bzw. was ich ändern muss, damit es auch mit MySQL5 läuft?
SQL-Code:
SELECT u.username, u.user_id, g.group_id AS single_usergroup, g2.group_id AS group_moderator
FROM phpbb_users u, phpbb_user_group ug, phpbb_groups g LEFT JOIN phpbb_groups g2 ON g2.group_moderator = u.user_id WHERE ug.user_id = u.user_id AND g.group_id = ug.group_id AND g.group_single_user = 1 AND u.user_id IN(35, 36) Die Fehlermeldung: #1054 - Unknown column 'u.user_id' in 'on clause' |
Re: Query läuft bei MySQL4(.1), bei MySQL5 aber nicht
Versuch mal, Aliase für alle später verwendeten Felder zu vergeben und dann auf diese Aliase in ON und WHERE abzufragen.
|
Re: Query läuft bei MySQL4(.1), bei MySQL5 aber nicht
Deine SQL Anweisung ist etwas unsauber geschrieben.
Wenn du Tabellen Joinen möchtest gibt es eine alte und eine neue Syntax. Du verwendest beiden Arten in einer Anweisung: Alte Syntax:
SQL-Code:
Neue Syntax:
SELECT .... FROM TabA,TabB
WHERE TabA.Feld1=TabB.Feld2
SQL-Code:
Die neue Syntax zeigt die Verknüpfung zwischen den Tabellen viel deutlicher als die alte Syntax.
SELECT .... FROM
TabA INNER JOIN TabB ON TabA.Feld1=TabB.Feld2 |
Re: Query läuft bei MySQL4(.1), bei MySQL5 aber nicht
@shmia: Ich habe jetzt das Query auf INNER JOINS umgeschrieben:
SQL-Code:
So läuft es jetzt unter MySQL5. Kannst du mir noch sagen, warum sie diesen alten Syntax rausgeworfen haben? Im Prinzip wäre es doch logischer, wenn die alten Möglichkeiten auch weiterhin möglich sind!? Durch das neue Query entstehen nämlich z.B. in meinem Fall andere Probleme, da das phpBB mit mehreren DB-Systemen arbeitet und einige davon wahrscheinlich mit dem alten besser auskommen würden als mit dem neuen. :?
SELECT u.username, u.user_id, g.group_id AS single_usergroup, g2.group_id AS group_moderator
FROM phpbb_users u INNER JOIN phpbb_user_group ug ON ug.user_id = u.user_id INNER JOIN phpbb_groups g ON g.group_id = ug.group_id AND g.group_single_user = 1 LEFT JOIN phpbb_groups g2 ON g2.group_moderator = u.user_id WHERE u.user_id IN(35, 36) |
Alle Zeitangaben in WEZ +1. Es ist jetzt 10:33 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz