php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 20.10.2009, 13:23  
Neuer Benutzer
 
Registriert seit: 29.03.2009
Beiträge: 20
grunz befindet sich auf einem aufstrebenden Ast
Standard SQL - Abfrage: letzte Kommentare

Hi!

Ich finde für eine bestimmte Problemstellung einfach nicht die richtige SQL Abfrage.
Ich möchte die letzten x Beiträge, Kommentare, o.ä. zu einem Beitrag, Post, Video, Foto, usw. ausgeben, dabei mehrfaches Auftauchen eines Beitrags,... vermeiden.

Ich versuche das ganze mal an einem Beispiel zu verdeutlichen, ist wahrscheinlich für erfahrene SQL Benutzer kein Problem.

Beispiel: Bildatenbank
Tabelle 1 enthält Informationen zu einem Bild:
id, ersteller, titel, beschreibung, einstellungsdatum, ...

Tabelle 2 enthält Kommentare zu Bildern:
id, bild_id, autor, titel, text, erstellungsdatum, ...

Jetzt will ich einfach die letzten/neuesten 5 Kommentare ausgeben, allerdings zu verschiedenen Bilder. D.h. wenn ein Bild innerhalb der letzten Stunde 10 Kommentare bekommen hat, will ich nur den neuesten davon unter meiner Ausgabe der letzten 5 Kommentare haben. Es sollen also die neusten 5 Kommentare zu 5 verschiedenen Bildern angezeigt werden.

Ich hoffe ich habe mich verständlich ausgedrückt.
grunz ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 20.10.2009, 13:26  
Supermoderator HD
 
Benutzerbild von Manko10
 
Registriert seit: 16.03.2008
Beiträge: 8.706
PHP-Kenntnisse:
Fortgeschritten
Manko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende Zukunft
Standard

Was du beschreibst, ist doch gar nicht so kompliziert, wie du dich ausdrückst oder verstehe ich dich falsch? Die neusten fünf Kommentare heißt doch eigentlich nur die neusten fünf Kommentare und nichts weiter. Jetzt musst du zu diesen neusten fünf Kommentaren nur noch die entsprechenden Videos heraussuchen, was ein simpler Join für dich erledigt.
Oder möchtest du zwangsläufig, dass es verschiedene Videos sein müssen?
__________________
Refining Linux Advent Calendar series “24 Outstanding ZSH Gems
Manko10 ist offline   Mit Zitat antworten
Alt 20.10.2009, 13:28  
Neuer Benutzer
 
Registriert seit: 29.03.2009
Beiträge: 20
grunz befindet sich auf einem aufstrebenden Ast
Standard

Es sollen verschiedene Videos/Bilder oder was auch immer sein...
grunz ist offline   Mit Zitat antworten
Alt 20.10.2009, 13:33  
Supermoderator HD
 
Benutzerbild von Manko10
 
Registriert seit: 16.03.2008
Beiträge: 8.706
PHP-Kenntnisse:
Fortgeschritten
Manko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende ZukunftManko10 hat eine strahlende Zukunft
Standard

Zingend? Oder geht es auch, dass ein Video zweimal angezeigt wird, wenn zwei der letzten fünf Kommentare für ein und dasselbe Video abgegeben wurden?
Wenn es zwingend ist, dann nutze noch ein GROUP BY für die Video-ID.
__________________
Refining Linux Advent Calendar series “24 Outstanding ZSH Gems
Manko10 ist offline   Mit Zitat antworten
Alt 20.10.2009, 14:08  
Neuer Benutzer
 
Registriert seit: 29.03.2009
Beiträge: 20
grunz befindet sich auf einem aufstrebenden Ast
Standard

ja zwingend.

Wie würde das denn mit group by genau aussehen?
Hatte damit zwar mal was versucht, aber auch nicht das richtige Ergebnis bekommen.
grunz ist offline   Mit Zitat antworten
Alt 20.10.2009, 17:28  
erc
Erfahrener Benutzer
 
Registriert seit: 02.01.2009
Beiträge: 730
PHP-Kenntnisse:
Fortgeschritten
erc wird schon bald berühmt werden
Standard

Das ist ein Problem was sich mit (MY)SQL nicht sinnvoll lösen lässt. In
http://www.php.de/datenbanken/60256-...datensatz.html habe ich eine mögliche Lösung gepostet, jedoch ist diese aus Performance gründen nicht überall sinnvoll verwendbar.

Ansonsten:

-einfach mehrere Queries ausführen
-wenn nur der letzte zugehörigen Datensatz gesucht wird, gehts auch mit INNER JOIN, MAX und GROUP BY
-mehr Datensätze auslesen als nötig und in der Anwendung filtern. Funktioniert aber nur bedingt, die Daten müssen gleichmässig verteilt sein, ansonsten muss man entweder zuviele Datensätze auslesen oder erhält ein "unbefriedigendes" Ergebnis.
erc ist offline   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
Problem mit Abfrage - join, inner join, distinct? Gachet01 Datenbanken 2 27.01.2011 06:49
Scriptsuche [Erledigt] SQL- Abfrage über 2 tabellen ejim Scriptbörse 1 17.07.2009 21:10
[Erledigt] Problem mit SELECT Abfrage BlackBroom Datenbanken 4 28.05.2009 14:13
SQL Abfrage ohne DESC langsam Thisi Datenbanken 5 07.01.2009 09:53
Wiemache ich eine Abfrage über 3 Tabellen??? djscaleo Datenbanken 8 05.01.2009 10:46
MySQL - Fehler in einfacher Abfrage oden Datenbanken 11 03.01.2009 20:03
[Erledigt] mysql abfrage über 4 Tabelle - bis 3 geht, bei der 4. habert Datenbanken 2 08.09.2005 11:59
[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 zweier Tabellen mit COUNT() funktion Datenbanken 23 20.09.2004 22:13
Abfrage funktioniert zwar, aber nicht korrekt Datenbanken 2 16.08.2004 09:10
Abfrage aus DB noch mal ausgeben und Abfrage aus mehrern Tab PHP Tipps 2004 4 12.07.2004 15:00
[Erledigt] Fehlerhafte Abfrage ? Datenbanken 15 24.06.2004 17:10

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
sql abfrage die letzten 5 einträge, sql nur letztes ergebnis, join letztes ergebnis, sql abfrage die letzte, sql abfrage nur die letzten x eintrage, sql abfrage von beiträgen der letzten stunde, sql aktionen innerhalb der letzten stunde?, letzten 5 unterschiedlichen sql, sql abfrage der letzten 5 produkte, sql letzten zugehörigen, sql letzte kommentar, sql abfrage letzte id, sql abfrage letzte stunde, letzte kommentare php, sql where abfrage letzten stunden, kommentare php sql, group by max zugehörige id, php sql nur den neusten satz anzeigen, sql nur letztes ergebnis anzeigen, sql kommentare abfragen

Alle Zeitangaben in WEZ +2. Es ist jetzt 08:51 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