Archiv verlassen und diese Seite im Standarddesign anzeigen : Doppelte IDs beim SQL-Query
Hendrik33 22-09-2010, 06:28 Hallo ich habe folgendes Problem,
ich möchte die IDs anhand anhand der aktualität ihrer neusten nachrichten auslesen:
Code:
SELECT user_messages.id FROM user_messages,user_messages_data WHERE user_messages.an='1' AND
user_messages_data.message=user_messages.messageid ORDER by user_messages_data.datum DESC
Ergibt:
id
45
45
38
38
38
40
19
38
41
40
usw ...
Klappt ja soweit alles, bis ausser dass es nicht sein darf dass er IDs die schon ausgelesen wurden einfach nochmal ausgibt ... Das ist nicht der Sinn, sonst habe ich die Hauptnachrichten am Ende mehrmals drin stehen für jeden Subbeitrag/Antwort darauf in der user_messages_data Tabelle...
Wer kann mir bei diesem Problem helfen? Wie müsste der Code angepasst werden?
Danke im Vorraus!
Hendrik
eagle275 22-09-2010, 06:55 ein DISTINCT ( ...id) liefert dir jede nur einmal
Hendrik33 22-09-2010, 09:13 Select distinct(user_Messages.id) from ...
So richtig?
SQL-Keywords bitte immer GROß SCHREIBEN, damit man sie unterscheiden kann (mag bei deinen Queries noch nicht relevant sein, aber glaubs mir: Es erleichtert dir den Überblick enorm)
Hendrik33 22-09-2010, 09:55 Mach ich ja immer ... Nur bin am iPhone da ist es ja Net so wichtig jetzt ;) denke die pros unter euch Checkens schon
Klar, ging mir auch nicht darum, dass die Leute hier es verstehen, sondern dass es für dich leichter wird. Aber wenn du es eh machst ist es gut ;-)
eagle275 22-09-2010, 10:14 jo . damit sollte MySQL tun, was du wünschst ...
Hendrik33 22-09-2010, 14:41 Also ...
SELECT DISTINCT(user_messages.id) FROM user_messages,user_messages_data WHERE user_messages.an='1' AND
user_messages_data.message=user_messages.messageid ORDER by user_messages_data.datum DESC
das klappt schonmal das immer nur einmal jetzt die ID ausgelesen wird...
aber er sortiert nicht nach dem Datumsfeld user_messages_data.datum ???
Weil das nicht möglich ist. Was ist, wenn eine ID zwei verschiedene Datumwerte hat? Wer entscheidet, nach welchem sortiert wird? Du musst der Datenbank schon genau mitteilen WAS du eigentlich haben willst.
Hendrik33 22-09-2010, 15:05 Also ich erklärte mal die Struktur:
user_messages mit den Felder:
id
von
an
betreff
datum
messageid
user_messages_data mit den Felder:
id
user
message
text
datum
Wenn ich eine Nachricht erstelle wird in Tabelle user_messages geschrieben:
id= fortlaufend
von=empfängerid z.b. 1
an=empfängerid z.b. 20043
betreff= irgendwas
datum=timestamp vom erstellen der nachricht
messageid= wird nachträglich per update Befehl (mysql_insert_id()) die id gegeben die gerade angelegt wurde vom feld id...
im der tabelle user_messages_data wird eingetragen:
id=fortlaufend
user=id vom absender der nachricht
message=zahl aus dem feld messageid bei der ersten tabelle
text=irgendeinen text ...
datum=aktueller timestamp
Was ich jetzt auslesen will ist ... Er soll alle Nachrichtenthemen anzeigen und soll die IDs so anordnen dass die aktuellste Nachricht (also sprich dort wo die neuste Antwort drinnen ist ...) ganz oben steht ...
Wie müsste man das machen?
P.S. Falls es keine Lösung gibt für mein vorhaben wäre die alternative dass ich bei jeder antwort das feld lastmessagetime einrichte in der ersten tabelle und müsste dieses jedes mal ändern lassen bei nem beitrag, so dass ich danach dann die ids sortiere oder?
AmicaNoctis 22-09-2010, 15:20 Hallo,
wo steht denn die neueste Antwort? In user_messages_data mit derselben messageid oder in user_messages selbst? Wofür ist die user_messages_data gut? Und wenn wir schon dabei sind, wofür ist messageid gut, wenn es immer denselben Wert hat wie die id?
Gruß,
Amica
Hendrik33 22-09-2010, 15:35 Alle Beiträge zu einem Thema stehn in user_messages_data mit der gleichen messageid ...
Wenn man an einen User was sendet wird ne neue ID erzeugt in user_messages ... diese wird dann mit update in das feld messageid geschrieben nach dem anlegen (mysql_insert_id()) ...
wenn der user jetzt antwortet dann wird auch wieder ein eintrag gemacht aber halt anderst herum beim ersten war an=1 und von =2 und beim nächsten eintrag wäre an=2 von=1 ... damit jeder in seinem eingang das thema sieht? hoffe ich hab es verständlich ausgedrückt ;)
AmicaNoctis 22-09-2010, 15:40 D. h. die messageid einer Nachricht ist also nicht immer ihre eigene ID sondern die der ersten Nachricht desselben Themas?
Wenn nicht, hab ich trotz intensivster Bemühungen dein Kauderwelsch nicht verstanden.
Hendrik33 22-09-2010, 15:46 Das ist der MySQL Export:
Hier müsste man das sehen können.
Es sind 2 verschiedene Nachrichten angelegt (Messageid 9 und 12) ...
Diese sollen jetzt anhand der vorhanden Beiträge (jeweils 2 Stück zu jeder Nachricht) darin nach Datum des neusten Beitrags sortiert werden ...
Tabellenstruktur für Tabelle `user_messages`
CREATE TABLE IF NOT EXISTS `user_messages` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`messageid` text NOT NULL,
`von` text NOT NULL,
`an` text NOT NULL,
`betreff` text NOT NULL,
`datum` text NOT NULL,
`new` text NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=52 ;
Daten für Tabelle `user_messages`
INSERT INTO `user_messages` (`id`, `messageid`, `von`, `an`, `betreff`, `datum`, `new`) VALUES
(9, '9', '67', '1', 'danke', '1284994877', ''),
(11, '9', '1', '67', 'danke', '1284995311', '1'),
(12, '12', '20', '3', 'dddd', '1284994877', ''),
(13, '12', '3', '20', 'dddd', '1284994897', '');
Tabellenstruktur für Tabelle `user_messages_data`
CREATE TABLE IF NOT EXISTS `user_messages_data` (
`id` int(11) NOT NULL AUTO_INCREMENT,
`message` text NOT NULL,
`user` varchar(11) NOT NULL,
`text` text NOT NULL,
`datum` text NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=90 ;
Daten für Tabelle `user_messages_data`
INSERT INTO `user_messages_data` (`id`, `message`, `user`, `text`, `datum`) VALUES
(88, '9', '1209', 'hi wie gehts?', '1285155091'),
(89, '9', '247', ':no11: ', '1285158920'),
(95, '12', '88', 'test ....', '1285158920'),
(96, '12', '123', 'lalala', '1285158930');
AmicaNoctis 22-09-2010, 15:58 Das ergibt keinen Sinn. Erstmal die text-Spalten, in denen am Ende doch nur ein nummerischer Schlüssel drin steht. Dann die user_messages_data-Einträge, die sich nur auf message 9 und 12 beziehen - was steht denn dann in 11 und 13 drin? Absolut nicht nachvollziehbar.
Hendrik33 22-09-2010, 16:04 Natürlich ergibt das einen Sinn ...
Wenn man die Nachricht anzeigt ich schreib schnell den Code damit mans versteht (bitte nicht meckern wenn er so nicht geschrieben wird - funktionieren tuts trotzdem)
Der Benutzer ruft das Script auf mit der id 11 dann wird ausgelesen welche messageid es betrifft ...
$auslesen=mysql_query("SELECT * FROM user_messages WHERE id='11'");
while($fetch=mysql_fetch_array($auslesen)) {
$auslesenx=mysql_query("SELECT * FROM user_messages_data WHERE message='$fetch[messageid]'");
while($fetchx=mysql_fetch_array($auslesenx)) {
echo "$fetchx[text]";
}}
So würde mann z.b. alle posts zur nachricht mit der id 11 bzw der messageid 9 bekommen ...
Jetzt verstanden?
AmicaNoctis 22-09-2010, 16:06 Bitte beitrag ändern und Code-Tags benutzen.
Edit: Okay, Code-Tags hast du inzwischen, http://www.php-resource.de/forum/images/editor/php.gif-Code-Tags wären noch besser.
Jetzt verstanden?
Nein.
Hendrik33 22-09-2010, 16:14 Ich weiß nicht wie ichs erklären soll, also nochmal
user 1 schickt an user 2 eine nachricht
dann wird in die tabelle user_messages ne zeile eingetragen ...
Das Feld id ist forlaufend ... Das Feld messageid wird erst nach dem eintragen sofort danach via update table SET messageid='mysql_insert_id...' beschrieben ....
der AUTO Increment würde hier z.b. sein 12
die nachricht selber wird in user_messages_data gespeichert
das feld message bekommt hier auch die 12, damit es der nachricht zugeordnet ist ...
wenn der andere user jetzt auf die nachricht anwortet wird wieder ne zeile eingetragen in user_messages aber mit der messageid von der aufgerufenen nachricht die z.b. mal per input hidden übertragen wird ...
da es ja ne neue zeile gibt in der der an und von wert jetzt andersum sind damit der eigentliche absender der zuerst ne nachricht an einen gesendet hat ja die nachricht dann auch sehen muss .... das feld id wandert eben jetzt auf 13 kriegt aber in messageid die 12 von gerade eben ... denn beide müssen ja zur ursprungsnachricht was schreiben ...
jetzt kapiert? gibts ja net ;)
AmicaNoctis 22-09-2010, 16:28 Das hatte ich schon lange kapiert. Trotzdem ergibt es keinen Sinn. Laut deinem Dump gibt es Thread 9 und Thread 12. Jeder davon hat 2 Nachrichten: Thread 9: 9, 11 und Thread 12: 12, 13, oder anders ausgedrückt:
9, von 67, an 1, betreff: danke, gehört zu sich selbst
11, von 1, an 67, betreff: danke, gehört zu 9
12, von 20, an 3, betreff: dddd, gehört zu sich selbst
13, von 3, an 2, betreff: dddd, gehört zu 12
Soweit ist ja alles klar, aber jetzt kommen die Nachrichtentexte:
88, gehört zu 9, gesendet von 1209, text: hi wie gehts?
Warum 1209 und nicht 67? Aber es geht noch weiter:
89, gehört auch zu 9, gesendet von 247, text: :no11:
Beide gehören zur 9? Was soll denn dann dort drin stehen? Wie soll man dann noch wissen, was von wem an welchen Empfänger ging? Dafür gibt es aber keinen Text (user_messages_data), der zu Nachricht 11 (und auch 13) gehört. Die ist also leer, dafür weiß man aber, wer sie geschrieben hat und für wen sie gedacht war. Genau das ist nicht nachvollziehbar.
Jetzt kapiert?
Hendrik33 22-09-2010, 16:36 Warum 1209 und nicht 67? Aber es geht noch weiter:
89, gehört auch zu 9, gesendet von 247, text: :no11:
Beide gehören zur 9? Was soll denn dann dort drin stehen? Wie soll man dann noch wissen, was von wem an welchen Empfänger ging? Dafür gibt es aber keinen Text (user_messages_data), der zu Nachricht 11 (und auch 13) gehört. Die ist also leer, dafür weiß man aber, wer sie geschrieben hat und für wen sie gedacht war. Genau das ist nicht nachvollziehbar.
Jetzt kapiert?
Du hast Recht ;)
Das muss so heissen anstatt 1209 z.b. bei 88 die 1 und bei 89 die 67 ;)
(88, '9', '88', 'hi wie gehts?', '1285155091'),
(89, '9', '1209', ':no11: ', '1285158920'),
Wäre aber garnicht so tragisch es kommt ja auf die das Feld message mit der 9 und auf das datum an vom neusten ... Aber du hast Recht! Fehler von mir!
AmicaNoctis 22-09-2010, 16:48 Ok, dass die IDs falsch waren ist eine Sache, aber die andere ist offenbar noch nicht angekommen: Du speicherst die Nachrichtentexte immer zu der Nachricht, die den Thread selbst darstellt, anstatt sie zu der Nachricht zu speichern, zu der sie gehören. Deine DB-Struktur ist total chaotisch und die vielen text-Spalten die eigentlich int sein sollten, tun ihr übriges, jegliche Performance im Ansatz zu ersticken.
Vorschlag: setz die DB neu und normalisiert auf und kümmere dich dann um die Abfragen. Im Moment sieht das nach WOMBAT aus.
Hendrik33 22-09-2010, 16:52 Das mit den Feldtypen kann ich ja ändern ;) gebe ich dir recht aber wie soll es denn anderst gehen ?? Es muss ja für jeden User ein Eintrag geben in der Tabelle user_messages deswegen musste ich die messageid untergliedern ... kann ja nicht nach id gehen weil das wären ja zwei verschiedene :(
eagle275 22-09-2010, 17:33 wieso MUSS es für jeden User einen Eintrag dort geben ?
angenommen der User meldet sich an und erkrankt dann (Beinbruch , komplizierter Heilungsverlauf *g*) und kommt für 6 Monate nicht dazu was zu schreiben - ergo würde ich NICHT erwarten, dort etwas von ihm zu finden, weil der User ja gar keinen Nachrichten Thread starten konnte
Hendrik33 22-09-2010, 17:57 Es ist doch langsam der Wurm drin :D
Jetzt nochmal ganz von neu!
Es gibt Benutzer A (ID 1100)
Es gibt Benutzer B (ID 2211)
Fallbeispiel:
Benutzer A sendet eine Nachricht an Benutzer B
Tabellenstruktur:
--------------------------------
Name: user_messages
Feld: id (auto_increment)
Feld: von
Feld: an
Feld: betreff
Feld: datum
Feld: messageid
--------------------------------
user_messages_data mit den Felder:
Feld: id (auto_increment)
Feld: user
Feld: message
Feld: text
Feld: datum
Legen wir los:
Benutzer A sendet eine Nachricht an Benutzer B
// Nachricht anlegen
mysql_query("INSERT INTO user_messages SET von='1100', an='2211', betreff='Beispielbetreff', datum='1285170518'");
mysql_query("UPDATE user_messages SET messageid='".mysql_insert_id()."' WHERE id='".mysql_insert_id()."'");
// Infos zur Nachricht speichern und zuordnen
mysql_query("INSERT INTO user_messages_data SET user='1100', message='".mysql_insert_id()."', text='Beispieltext von Benutzer A', datum='1285170518'");
Die Nachricht wurde gespeichert und wird jetzt beim anderen Benutzer im Posteingang angezeigt
Weiter gehts ;)
Jetzt antwortet Benutzer B an A!
Die MessageID von der ersten Nachricht wird per hidden field übertragen aus dem FORM
// Nachricht anlegen
mysql_query("INSERT INTO user_messages SET messageid='1 da wir von einern leeren Tabelle ausgehen', von='2211', an='1100', betreff='Beispielbetreff', datum='1285170690'");
// Infos zur Nachricht speichern und zuordnen
mysql_query("INSERT INTO user_messages_data SET user='2211', message='1', text='Beispieltext von Benutzer b', datum='1285170690'");
So werden die Nachrichten eingetragen ...
Jetzt müssen alle Nachrichten von Benutzer 2211 ausgelesen werden z.B.
SELECT DISTINCT(user_messages.id) FROM user_messages,user_messages_data WHERE user_messages.an='2211' AND
user_messages_data.message=user_messages.messageid ORDER by user_messages_data.datum DESC
Dieser Code würde nur alle id`s auflisten aber nicht nach datum sortiert.
Was ich wissen möchte ist wie der Query lauten müsste damit es nach Datum der letzten Nachricht sortiert wird. Denkt daran das Datum steht in der Tabelle user_messages_data und Feld datum ... Jeder Post hat ja immer einen Timestamp ... Das Feld Datum in der Tabelle user_messages ist das Datum wann die Hauptnachricht vom Erstsender gesendet wurde ...
Hoffe das ist jetzt gut erklärt!
AmicaNoctis 22-09-2010, 18:10 @eagle: Du solltest langsam mal anfangen, Threads komplett zu lesen, bevor du deine Meinung über etwas kundtust, was du ausschließlich aus dem letzten Beitrag entnehmen zu können glaubst.
@Hendrik: Der Ablauf ist klar, aber wenn du alle Nachrichtentexte (in diesem Falle die Antwort) zur allerersten Nachricht (in diesem Falle die 1) speicherst, kannst du nicht mehr zuordnen, zu welcher Nachricht der Text jetzt wirklich gehört. In deinem Beispiel ist der Antworttext (user_messages_data 2) nicht mehr der Antwort selbst (user_messages 2) zuzuordnen, weil er ja nur noch auf die user_messages 1 verweist. Das kann zu einem großen Problem werden und das meinte ich die ganze Zeit schon.
Hendrik33 22-09-2010, 18:15 Super wenn das schonmal klar ist!
Aber das verstehe ich nicht was du sagst ...
Angenommen in Tabelle 1 hat die id vorne die 1283 was ja mit dem eigentlichen garnichts zu tun hat ...
Die messageid hat jetzt mal 33 ...
In der zweiten Tabelle haben dann alle Antworten bzw. Beiträge der beiden User im Feld message den Wert 33 ???
Wieso soll es da Probleme geben?
AmicaNoctis 22-09-2010, 18:28 Beispiel:
Für die Übersichtlichkeit mal angenommen:
Alle 10er sind User-IDs
Alle 20er sind Message-IDs
Alle 30er sind Message-Data-IDs
Folgende Konversation zwischen Herbert (11) und Anni (12):
Herbert: Hallo Anni
Anni: Hallo Herbert, na wie geht's?
Herbert: Super.
Herbert: und dir?
Anni: Auch super.
Anni: hast du was von Locke gehört?
Herbert: Bis jetzt nicht.
user_messages
id messageid von an
21 21 11 12
22 21 12 11
23 21 11 12
24 21 11 12
25 21 12 11
26 21 12 11
27 21 11 12
user_messages_data
id message user text
31 21 11 Hallo Anni
32 21 12 Hallo Herbert, na wie geht's?
33 21 11 Super.
34 21 11 und dir?
35 21 12 Auch super.
36 21 12 hast du was von Locke gehört?
37 21 11 Bis jetzt nicht.
So machst du es im Moment und du hast jetzt keine Möglichkeit mehr, herauszufinden, was in user_messages 23 geschrieben wurde. Umgekehrt ist es schwierig herauszufinden, wem Anni in user_messages_data 35 geschrieben hat.
Das ist das Problem: du hast keine Verbindung zwischen einer Nachricht und ihrem Text.
Hoffe, es ist jetzt klarer geworden.
Hendrik33 22-09-2010, 18:38 Ahhh so meinst du das, nein das ist so...
Es gibt wenn beide sich geschrieben haben insgesamt nur 2 Zeilen einmal:
Für eine Message ID wird es immer nur 2 Einträge geben einmal mit von und an in jeweils umgekerhter Reihenfolge ;)
an 1
von 2
und umgekerht ... also
user_messages
id messageid von an
21 21 11 12
22 21 12 11
mehr nicht ... (das wird per php script geprüft ob der eintrag schon existiert)
Verstehst du? Es klappt ja alles wunderbar ...
Nur das sortieren nach dem aktuellsten weiß ich nicht wie ichs machen muss ...
AmicaNoctis 22-09-2010, 18:42 Nach welchem datum willst du denn sortieren? Nach dem in user_messages oder in user_messages_data?
Edit: Wenn es bei dir immer nur eine Antwort gibt, kann also niemand auf eine Antwort antworten, sondern muss ein neues Thema erstellen?
Hendrik33 22-09-2010, 18:51 Es soll nach dem Datum aus der Messages Data Tabelle gehen ;) wieso sollte das nicht gehen ... Stell dir das vor wie ein Chat zwischen den beiden Benutzern ...
AmicaNoctis 22-09-2010, 18:57 Es soll nach dem Datum aus der Messages Data Tabelle gehen
Dann selektier mal max(datum) und gruppiere es nach message. Wenn du jetzt noch einen Join auf user_messages machst, bekommst du die anderen Infos auch noch mit.
Stell dir das vor wie ein Chat zwischen den beiden Benutzern ...
Wie du siehst, bin ich dir da weit voraus. Ich habe es mir ja schon als solches vorgestellt und ein Beispiel geliefert. Jetzt interessiert es mich, wie mein Beispiel bei dir aussieht, wenn es keine Antworten auf Antworten gibt. ;)
Hendrik33 22-09-2010, 19:18 Was meinst du mit antworten auf antworten !???? Das verstehe ich noch nicht so
AmicaNoctis 22-09-2010, 19:25 Herbert: Hallo Anni
Anni: Hallo Herbert, na wie geht's?
Herbert: Super.
Herberts "Super." ist eine Antwort auf eine Antwort. Wie stellst du das dar?
Hendrik33 22-09-2010, 19:48 Wie schon auf Seite 2 beschrieben.
$auslesen=mysql_query("SELECT * FROM user_messages WHERE id='11'");
while($fetch=mysql_fetch_array($auslesen)) {
$auslesenx=mysql_query("SELECT * FROM user_messages_data WHERE message='$fetch[messageid]' ORDER BY datum DESC");
while($fetchx=mysql_fetch_array($auslesenx)) {
echo "$fetchx[text]";
}}
Directupload.net - Dxe96m5x9.jpg (http://s10.directupload.net/file/d/2290/xe96m5x9_jpg.htm)
Screenshot ist hier wie das in ganzer Form aussieht ...
Das auslesen zu ner Nachricht an sich, also die ganzen Beiträge zu einer Nachricht ist no Problem das geht ja einwandfrei wie du siehst ...
Nur die übersicht ... wie hier die Forenthemen das meine ich dass Nachrichten mit den neusten Antworten absteigend sortiert werden wie auch hier in der Foren Kategorie ansicht, steht ja auch immer das neuste Thema oben... das könnten ja genau so nachrichten von benutzer zu benutzer sein ;)
Verstehste?
AmicaNoctis 22-09-2010, 20:06 Entweder gehst du nicht auf meine Fragen ein oder du verstehst mich nicht. Wir kommen hier nicht weiter, glaub ich. Jedenfalls hab ich jetzt langsam keinen Nerv mehr dafür. Ich frag dich, wie du Unterhaltungen mit mehreren (Rück-) Antworten darstellst und du knallst mir eine Abfrage hin und rundest das Ganze wieder mit deinem "Verstehste?" ab. Ich glaube, behaupten zu dürfen, dass ich mich lange genug mit PHP und Datenbanken beschäftigt habe, um das zu verstehen. Wenn ich wirklich zu begriffsstutzig wäre, um dir folgen zu können, wäre sicher mal jemand anderes an meiner Stelle eingesprungen. Deine DB-Struktur ist großer Käse und ich hab erst lange überlegt, ob ich auf diesen Thread was schreibe, weil ich erst nicht wusste, wo ich anfangen soll, dir zu erklären, warum du das Ganze besser nochmal neu angehen solltest. ;)
Viel Erfolg.
Hendrik33 22-09-2010, 20:10 Sry AmicaNoctis
Ich habe oben meinen Abfrage Code hingepostet der list alle Antworten zu der jeweiligen Message ID aus? Hab ich doch gepostet! Was ich doch suche und wo ich eure Hilfe brauche ist die Liste von Nachrichten die ich generell habe, dort sollen oben die neusten stehen ...
:( Irgendwie perplex heute :( :( :(
AmicaNoctis 22-09-2010, 20:12 Warum machst du es dann nicht einfach so, wie ich bereits gesagt hatte:
http://www.php-resource.de/forum/php-developer-forum/100319-doppelte-ids-beim-sql-query.html#post645744
... oder stellst konkrete Fragen dazu, falls du es nicht verstehst?
Hendrik33 22-09-2010, 20:27 Ich weiß keinen Ansatz :(
SELECT xy FROM tabelle WHERE datum = (SELECT MAX(datum) FROM tabelle)
das habe ich gefunden weiß aber nicht wie ich das in den Query integrieren soll :(
AmicaNoctis 22-09-2010, 20:45 Ich weiß keinen Ansatz :(
Keine SQL-Vorkenntnisse?
Fang damit an:
select max(datum) as date
from user_messages_data
group by message
order by date desc
Dann liest du dir was über Joins durch und holst dir den Rest der Informationen.
Hendrik33 22-09-2010, 20:55 Mit Hilfe von phpMyAdmin und deinem Ansatz hab ich es hinbekommen...
In phpMyAdmin funktioniert es!
Was sagst du zu dem Code? Kannst du das nachvollziehen?
SELECT DISTINCT(user_messages.id) FROM user_messages,user_messages_data WHERE user_messages.an='1'
AND user_messages_data.message=user_messages.messageid GROUP by user_messages.id ORDER BY
MAX(user_messages_data.datum) DESC
AmicaNoctis 22-09-2010, 20:56 Was sagst du zu dem Code?
Grausam, furchtbar, sofort umbrechen! ;)
Hendrik33 22-09-2010, 21:02 Grausam, furchtbar, sofort umbrechen! ;)
Und nun?
AmicaNoctis 22-09-2010, 21:28 Warum verwendest du keine ANSI-Style Join-Syntax, sondern diesen Theta-Style Kram, den niemand versteht und dann auch noch alles hintereinander?
So schreibt man das:
SELECT DISTINCT
um.id as id,
max(umd.datum) as date
FROM user_messages AS um
JOIN user_messages_data AS umd ON umd.message = um.messageid
WHERE um.an='1'
GROUP BY um.id
ORDER BY date DESC
|
-
- |