Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Query läuft bei MySQL4(.1), bei MySQL5 aber nicht (https://www.delphipraxis.net/67001-query-laeuft-bei-mysql4-1-bei-mysql5-aber-nicht.html)

S2B 7. Apr 2006 16:50

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'

Chewie 7. Apr 2006 16:54

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.

shmia 7. Apr 2006 16:59

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:
SELECT .... FROM TabA,TabB
WHERE TabA.Feld1=TabB.Feld2
Neue Syntax:
SQL-Code:
SELECT .... FROM
TabA INNER JOIN TabB ON TabA.Feld1=TabB.Feld2
Die neue Syntax zeigt die Verknüpfung zwischen den Tabellen viel deutlicher als die alte Syntax.

S2B 7. Apr 2006 17:09

Re: Query läuft bei MySQL4(.1), bei MySQL5 aber nicht
 
@shmia: Ich habe jetzt das Query auf INNER JOINS umgeschrieben:
SQL-Code:
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)
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. :?


Alle Zeitangaben in WEZ +1. Es ist jetzt 12:37 Uhr.

Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz