php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 22.02.2006, 21:59  
Gast
 
Beiträge: n/a
Standard 2 x FIND_IN_SET Abfrage (geht sicher auch einfacher)

Hallo,

ich habe eine Buddyliste mit 2 Spalten:

buddy_von (z.B. Anton)
buddy_fuer (z.B. Berta)

Anton|Berta -> Anton hat Berta auf seiner Liste

Damit beide aber "richtige" Buddies sind, muss Berta natürlich auch Anton auf ihrer Liste haben:

Anton|Berta
Berta|Anton

Soweit so gut, ich möchte alle Onlineuser in 3 Gruppen aufteilen:

- Buddies (Leute die sich gegenseitig in der Liste haben)
- Favoriten (wenn ich jemanden auf der Liste habe, derjenige mich aber nicht)
- Normalos (alle die nirgends in der Liste vorkommen)

So hab ich bisher immer abgefragt, ob sich 2 als Buddy haben (simples Beispiel damit ihr es versteht):

$user="Anton";
$kontakt="Berta";

Code:
$xxx=mysql_fetch_array(mysql_query("SELECT COUNT(*) FROM buddy WHERE FIND_IN_SET(buddy_von,'$user,$kontakt') AND FIND_IN_SET(buddy_fuer,'$user,$kontakt')"));
if($xxx[0]==2) --> beide haben sich auf der Liste
else if($xxx[0]==1) --> einer von beiden hat den anderen auf der Liste
else --> Normalos

Nun hab ich das Problem bei Ergebnis "1", da ich hier nicht weiß wer genau wenn auf der Liste hat. Ich brauch natürlich nur den Wert, dass ICH ($user) den $kontakt in meiner Liste habe, ob der andere mich in der Liste hat, ist egal....
  Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

Registriert seit: 21.08.2005
Beiträge: 4682
PHP-Kenntnisse:
Fortgeschritten

Alt 22.02.2006, 22:04  
Erfahrener Benutzer
 
Registriert seit: 20.01.2005
Beiträge: 1.557
PHP-Kenntnisse:
Fortgeschritten
Buhmann ist zur Zeit noch ein unbeschriebenes Blatt
Buhmann eine Nachricht über ICQ schicken Buhmann eine Nachricht über MSN schicken
Standard

Code:
$xxx=mysql_fetch_array(mysql_query("SELECT COUNT(*), FIND_IN_SET(buddy_von,'$user,$kontakt') AS favorit FROM buddy WHERE FIND_IN_SET(buddy_von,'$user,$kontakt') AND FIND_IN_SET(buddy_fuer,'$user,$kontakt')"));
wenn count 1 ist und favorit 1 ist, ist der ein favorit (ungetestet)
Buhmann ist offline   Mit Zitat antworten
Alt 22.02.2006, 22:15  
Gast
 
Beiträge: n/a
Standard

Danke, werd's gleich mal testen... mit dem AS kam mir auch irgendwie in den Sinn.
  Mit Zitat antworten
Alt 22.02.2006, 22:47  
Gast
 
Beiträge: n/a
Standard

Hm, MySQL meckert, weil man das noch GROUPen soll...

Bei Buddy:
Array ( [0] => 1 [COUNT(*)] => 1 [1] => 1 [favorit] => 1 )

Bei jemand den ich in der Liste hab, er mich aber nicht:
Array ( [0] => 1 [COUNT(*)] => 1 [1] => 1 [favorit] => 1 )

Bei jemand der mich in der Liste hat, ich ihn aber nicht:
Array ( [0] => 1 [COUNT(*)] => 1 [1] => 2 [favorit] => 2 )

Bei Normalo:
(kein Ergebnis)

Soweit okay, aber Buddy + Favorit liefert halt die gleichen Ergebnisse :-/
  Mit Zitat antworten
Alt 23.02.2006, 13:27  
Erfahrener Benutzer
 
Registriert seit: 13.11.2005
Beiträge: 2.583
xabbuh
Standard

Wie hast du deine Abfrage denn angepasst?
xabbuh ist offline   Mit Zitat antworten
Alt 23.02.2006, 15:53  
Gast
 
Beiträge: n/a
Standard

Ich hab's jetzt so gemacht (obwohl das sicher viel zuviel Code für so eine Abfrage ist):

PHP-Code:
<?php
SELECT buddy_fuer 
AS nicknameAS reihung
FROM buddy
WHERE buddy_von 
'".$_SESSION['sessuser']."'
AND buddy_fuer '$row[0]'
AND buddy_von
IN 
(SELECT buddy_fuer FROM buddy WHERE buddy_von='$row[0]'
AND buddy_fuer='".$_SESSION['sessuser']."')
UNION SELECT buddy_fuer AS nicknameAS reihung
FROM buddy
WHERE buddy_von 
'".$_SESSION['sessuser']."'
AND buddy_fuer '$row[0]'
AND buddy_von
NOT IN 
(SELECT buddy_fuer FROM buddy WHERE buddy_von='$row[0]'
AND buddy_fuer='".$_SESSION['sessuser']."')
ORDER BY reihung,nickname
?>
  Mit Zitat antworten
Alt 02.03.2006, 18:46  
Gast
 
Beiträge: n/a
Standard

überdenk einfach mal dein Datenbank-Design...

Dann ist das eine Zeile...

Beispiel:

Code:
Tabelle BENUTZER
id_nutzer      //hier eindeutige, beliebige Zahl (AUTO_INCREMENT, PRIMARY KEY)
vorname
nachname
straße
messenger
sonstwas

Code:
Tabelle BUDDIE
id_buddie      //hier eindeutige, beliebige Zahl (AUTO_INCREMENT, PRIMARY KEY)
id_nutzer      //Die NUTZER-Id des "BuddieHABENDEN"
id_nutzer_buddie   //Die NUTZER-Id des "Buddies von Nutzer-ID"
status    //z.B. TINYINT: 0 für unbestätigt, 1 für bestätigt, 9 für abgelehnt, usw...)
zeit   // Zeit des hinzufügens
sonstwas    //zur Buddie-Nutzer-BEZIEHUNG
Code:
SQL_QUERY "Wer ist mein Buddie?"
SELECT * from nutzer, buddie 
WHERE nutzer.id_nutzer=buddie.id_nutzer_buddie
AND nutzer.id_nutzer='$Meine id_nutzer'

Damit kannst Du viiieeel flexibler Arbeiten.
Stichwort für google oder so: Relationales Datenbankdesign

Schieb sowas nicht auf. Je später die Änderung an einer DB, umso der Umstellungsaufwand...

Das kann auch noch mit JOIN umgeschrieben werden, und natürlich benutze ICH nicht solche langen Namen im Quelltext... "idn" reicht aus für die Nutzer-ID
  Mit Zitat antworten
Alt 02.03.2006, 19:26  
Gast
 
Beiträge: n/a
Standard

Nun es ist ja jetzt mittlerweile mit IDs aufgebaut, allerdings kommt die Abfrage ja in etwa auf das gleiche raus (statt Usernamen eben die ID).

Problem ist halt immer noch, dass es eben nicht alles in einer Abfrage geht, sondern nur mit zusätzlichen Schleifen.

1) Ich frage alle Onlineuser ab und fische Ignorierte gleich raus:

Code:
SELECT userid,username
FROM stammdaten
WHERE onlinestatus>=1
AND userid NOT IN(SELECT fuer FROM igno WHERE von='ich')
ORDER BY
username ASC
2) Ich frage jede Zeile in einer extra Schleife nochmals ab:

Code:
SELECT fuer AS nickname, 2 AS reihung
FROM buddy
WHERE von='ich'
AND
fuer='$row[0]'
AND von IN (SELECT fuer FROM buddy WHERE von='$row[0]' AND fuer='ich')
UNION SELECT fuer AS nickname, 1 AS reihung
FROM buddy
WHERE von='ich'
AND fuer='$row[0]'
AND von NOT IN(SELECT fuer FROM buddy WHERE von='$row[0]' AND fuer='ich')
ORDER BY reihung,nickname
ich = bin ICH (meine userid) und $row[0] ist die aktuelle userid in der Schleife

Das liefert mir dann konkret zurück, wer Buddy ist, wer nicht Buddy ist und wer "Favorit" ist, sprich den ich in der Buddyliste habe, er mich aber nicht.

Ist halt bischen kompliziert, ginge sicher auch in einer einzigen Abfrage, aber dafür reicht mein Horizont noch nicht
  Mit Zitat antworten
Alt 03.03.2006, 10:10  
Gast
 
Beiträge: n/a
Standard

hmmh, also:

Das erste snippet geht so. Kannst es mit meinem kombinieren, und dann bekommst Deu eine Liste aller Buddies...

Allerdings musst Du dafür den onlinestatus in den stammdaten immer ändern. Sinnvoll wäre eine Tabelle Login, die ungefähr so aussieht

Code:
Tabelle LOGIN
id_login
userid
loginzeit
lastmove
logoutzeit
session_id
Dann kannst Du diese mit abfragen, wer noch online ist (keine Auslogzeit, Lastmove<20 Minuten)...


Das zweite Snippet verstehe ich nicht ganz. Wofür brauchst Du diese Schleife?
Eine Schleife macht eigentlich nur aus PHP oder so Sinn, wenn Du mit den einzelnen Feldern etwas anstellen willst. Wenn Du aber nur eine Liste haben willst, müsste doch eine Select-Abfrage reichen (siehe mein snippet davor)...
  Mit Zitat antworten
Alt 03.03.2006, 15:16  
Gast
 
Beiträge: n/a
Standard

Hey,

ich hatte vorher eine extra UserOnline-Tabelle, die machte allerdings wenig Sinn, da viele identische/benötigte Daten schon in der Stammdaten-Tabelle bereits vorhanden sind (UserID, Username, Alter, Geschlecht, ...).

Deswegen nehm ich jetzt gleich die Stammdaten-Tabelle als Basis und frage einfach immer alle User ab, die innerhalb der letzten 30 Sekunden per UPDATE aktualisiert wurden.

Zu meiner Abfrage:

1) angezeigt werden sollen nur User die online sind
2) zuerst "Freude", dann "Favoriten" und danach alle anderen die online sind
3) Freunde = gegenseitig auf Buddyliste, Favoriten = hab nur ich in Buddyliste
4) ev. von mir ignorierte User sollen erst gar nicht in der Liste auftauchen

stamm: userid | username | jahre | ...
1|Anton|23
2|Berta|18
3|Cäsar|34
4|David|27

buddy: buddyvon | buddyfuer
1|2
2|1
1|3

igno: ignovon | ignofuer
1|3

Ich bin also angenommen "Anton" und habe Berta als Buddy, sie mich auch. Weiterhin habe ich David als Buddy, er mich aber nicht (nur Favorit). Außerdem habe ich noch Cäsar als Ingnore, er soll also erst gar nicht erscheinen.

Theoretisch bräuchte ich also sowas zugerückgeliefert:

Code:
++++++++++++++++++++++++++++++++++++++
+ userid + username + jahre + status + 
++++++++++++++++++++++++++++++++++++++
+    2     + Berta  +  18   +     2  + 
+    4     + David  +  27   +     1  + 
+    1     + Anton  +  23   +     0  + 
++++++++++++++++++++++++++++++++++++++
Es muss also schon gruppiert nach Buddies, Favoriten und normalen Usern sein und ich muss die anhand einer Status-Nummer unterscheiden können...

Deshalb lasse ich wie oben mometan erstmal alle User abfragen die a)online sind und b) nicht in meiner Ignoreliste.

Danach halt eine Schleife mit allen Ergebenissen durchlaufen und prüfen ob in Buddyliste komplett drin, nur meinerseits oder gar nicht.
  Mit Zitat antworten
Antwort


Themen-Optionen
Thema bewerten
Thema bewerten:

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 an
Gehe zu

Ähnliche Themen
Thema Autor Forum Antworten Letzter Beitrag
Abfrage von einer Abfrage Datenbanken 5 27.01.2011 23:31
mysql abfrage in Schleife havok PHP Tipps 2006 6 09.05.2006 08:39
abfrage begrenzen Cyrus Datenbanken 4 26.10.2005 11:29
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
Abfrage in array? BartTheDevil89 Datenbanken 5 10.05.2005 14:21
[Erledigt] IF() abfrage in variable packen PHP Tipps 2005 14 01.04.2005 17:23
Abfrage von Char-Feldern Datenbanken 9 04.02.2005 14:06
[Erledigt] Mysql Abfrage Problem! PHP-Fortgeschrittene 5 27.11.2004 10:22
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
2 Tabellen 1 Abfrage nilsfeld Datenbanken 6 11.08.2004 11:18
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
komplizierte mySQL Abfrage Datenbanken 6 25.06.2004 15:34
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10
[Erledigt] mysql Abfrage Datenbanken 5 18.06.2004 14:16
[Erledigt] Variable per GET übergeben und DB Abfrage nutzen PHP Tipps 2004 4 01.06.2004 15:17

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
find_in_set, php find_in_set, where find_in_set, find_in_set(), sql find_in_set, find_in_set mehrere, mysql find_in_set 2 mal, mysql find_in_set mehrere werte, find_in_set vs in, select in find_in_set, find_in_set datenbank, sql find_in_set and, mysql query find_in_set example, select where find_in_set, where find_in_set and in, find_in_set >2, mysql \and find_in_set\, find_in_set with array, select find_in_set example, mysql find_in_set mit array

Alle Zeitangaben in WEZ +2. Es ist jetzt 20:29 Uhr.




Powered by vBulletin® Version 3.7.2 (Deutsch)
Copyright ©2000 - 2012, Jelsoft Enterprises Ltd.
Search Engine Optimization by vBSEO 3.2.0
Aprilia-Forum, Aquaristik-Forum, Liebeskummer-Forum, Zierfisch-Forum, Geizkragen-Forum

Creative Commons License
Dieser Inhalt ist unter einer Creative Commons-Lizenz lizenziert.