AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Query läuft bei MySQL4(.1), bei MySQL5 aber nicht
Thema durchsuchen
Ansicht
Themen-Optionen

Query läuft bei MySQL4(.1), bei MySQL5 aber nicht

Ein Thema von S2B · begonnen am 7. Apr 2006 · letzter Beitrag vom 7. Apr 2006
Antwort Antwort
Benutzerbild von S2B
S2B

Registriert seit: 1. Feb 2004
Ort: Aachen
1.268 Beiträge
 
#1

Query läuft bei MySQL4(.1), bei MySQL5 aber nicht

  Alt 7. Apr 2006, 16:50
Datenbank: MySQL • Version: 5.0.19-nt • Zugriff über: PHP
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'
Simon Praetorius
Gruß
S2B
  Mit Zitat antworten Zitat
Chewie

Registriert seit: 10. Jun 2002
Ort: Deidesheim
2.886 Beiträge
 
Turbo Delphi für Win32
 
#2

Re: Query läuft bei MySQL4(.1), bei MySQL5 aber nicht

  Alt 7. Apr 2006, 16:54
Versuch mal, Aliase für alle später verwendeten Felder zu vergeben und dann auf diese Aliase in ON und WHERE abzufragen.
Martin Leim
Egal wie dumm man selbst ist, es gibt immer andere, die noch dümmer sind
  Mit Zitat antworten Zitat
shmia

Registriert seit: 2. Mär 2004
5.508 Beiträge
 
Delphi 5 Professional
 
#3

Re: Query läuft bei MySQL4(.1), bei MySQL5 aber nicht

  Alt 7. Apr 2006, 16:59
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.
Andreas
  Mit Zitat antworten Zitat
Benutzerbild von S2B
S2B

Registriert seit: 1. Feb 2004
Ort: Aachen
1.268 Beiträge
 
#4

Re: Query läuft bei MySQL4(.1), bei MySQL5 aber nicht

  Alt 7. Apr 2006, 17:09
@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.
Simon Praetorius
Gruß
S2B
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 06: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