php.de

Zurück   php.de > Webentwicklung > Datenbanken

Datenbanken SQL und Co

Antwort
 
LinkBack Themen-Optionen Thema bewerten
Alt 25.12.2006, 18:43  
Erfahrener Benutzer
 
Registriert seit: 27.08.2003
Beiträge: 449
PHP-Kenntnisse:
Fortgeschritten
GSJLink
Standard Vor und Zurück ohne eindeutige ID

Hallo,
ich habe folgendes Problem. Ich habe 2 Tabellen: gallery und gallerypics.

Gallery:
ID | Name

Gallerypics:
ID | Name | GalleryID

Jetzt möchte ich ein Bild mit der "ID" = x ausgeben und darunter die Möglichkeit bieten auf der vorherige oder das nächste Bild innerhalb der "GalleryID" zu wechseln (ORDER BY "ID"). Das Problem dabei ist, dass ich nicht weiß, in der wievielten Zeile das Bild ist. Könnt ihr meinem Hirn mal nen bissl auf die Sprünge helfen? :wink:

mfg
Link
__________________
"Ein Script ist nur dann gut, wenn es unabhängig von der verwendeten Plattform funktioniert"
GSJLink ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 25.12.2006, 18:53  
Moderator
 
Benutzerbild von agrajag
 
Registriert seit: 02.10.2006
Beiträge: 3.820
PHP-Kenntnisse:
Fortgeschritten
agrajag wird schon bald berühmt werdenagrajag wird schon bald berühmt werden
Standard

Wo liegt denn jetzt konkret dein Problem?
Beispielquellcode?

Das sollte einfach über LIMIT gehen.
__________________
Today you...Tomorrow me.
agrajag ist offline   Mit Zitat antworten
Alt 25.12.2006, 18:55  
Erfahrener Benutzer
 
Registriert seit: 27.08.2003
Beiträge: 449
PHP-Kenntnisse:
Fortgeschritten
GSJLink
Standard

Wenn ich jetzt ein Bild über SELECT * FROM gallerypics WHERE id=x ausgebe, weiß ich nicht an welcher Position sich das in dem Ausschnit (WHERE galleryID = y) befindet.

Ich weiß, das zu verstehen ist schwierig ^^

mfg
Link
__________________
"Ein Script ist nur dann gut, wenn es unabhängig von der verwendeten Plattform funktioniert"
GSJLink ist offline   Mit Zitat antworten
Alt 25.12.2006, 19:01  
¯\_(ツ)_/¯
 
Benutzerbild von Flor1an
 
Registriert seit: 18.06.2008
Beiträge: 8.814
PHP-Kenntnisse:
Fortgeschritten
Flor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer Anblick
Standard

Gehen wir mal davon aus du hast diese Bilder hier

1, 2, 3, 6, 8, 10

angezeigt wird jetzt die 3 ... dann möchtest du einen Link auf Bild 2 und Bild 6 oder?

Der Link etwa so
gallery.php?action=next&current_id=3
gallery.php?action=prev&current_id=3

Im Skript machste dann:

SELECT ... FROM gallerypics WHERE id > 3 ORDER_BY id ASC LIMIT 0,1
SELECT ... FROM gallerypics WHERE id < 3 ORDER_BY id DESC LIMIT 0,1

etwa so ...
__________________
▇█▓▒░◕‿‿◕░▒▓█▇
Flor1an ist offline   Mit Zitat antworten
Alt 25.12.2006, 19:19  
Erfahrener Benutzer
 
Registriert seit: 27.08.2003
Beiträge: 449
PHP-Kenntnisse:
Fortgeschritten
GSJLink
Standard

Ok, ich habs jetzt so gemacht:

$id ist die ID der Gallerie
$pic ist die ID des Bildes

$next = "SELECT * FROM gallerypics WHERE id > $pic AND galleryid = $id ORDER BY id ASC LIMIT 0,1";
$ergebnis = mysql_query($next, $verbindung);
$next = mysql_fetch_object($ergebnis);

$nextid = $next->id;

$prev = "SELECT * FROM gallerypics WHERE id < $pic AND galleryid = $id ORDER BY id DESC LIMIT 0,1";
$ergebnis = mysql_query($prev, $verbindung);
$prev = mysql_fetch_object($ergebnis);

$previousid = $prev->id;


Danke für eure schnelle Hilfe

mfg
Link
__________________
"Ein Script ist nur dann gut, wenn es unabhängig von der verwendeten Plattform funktioniert"
GSJLink ist offline   Mit Zitat antworten
Alt 25.12.2006, 20:25  
¯\_(ツ)_/¯
 
Benutzerbild von Flor1an
 
Registriert seit: 18.06.2008
Beiträge: 8.814
PHP-Kenntnisse:
Fortgeschritten
Flor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer AnblickFlor1an ist ein wunderbarer Anblick
Standard

Mh ich hätte jetzt eigentlich nur gedacht dass du als Link garnicht die nächste oder vorherige ID angibst sondern beim klick auf next oder prev dann das Skript erst die nächste ID ausliest usw. so sparst du dir diese beiden Queries.
__________________
▇█▓▒░◕‿‿◕░▒▓█▇
Flor1an ist offline   Mit Zitat antworten
Alt 26.12.2006, 12:07  
Erfahrener Benutzer
 
Registriert seit: 27.08.2003
Beiträge: 449
PHP-Kenntnisse:
Fortgeschritten
GSJLink
Standard

Nun ja, ich wollte einfach, dass ich möglichst nicht sowenige Links haben will, dass ich später weniger Arbeit mit dem konfigurieren vom mod_rewrite habe

mfg
Link
__________________
"Ein Script ist nur dann gut, wenn es unabhängig von der verwendeten Plattform funktioniert"
GSJLink 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
Login, eindeutige Zuordnung auf eine Oberfläche Fleur PHP Tipps 2008 5 17.03.2008 15:38
Eindeutige User identifizierung JEGO PHP Tipps 2005-2 18 02.08.2005 13:23
*JS* Menü-Einträge eindeutige ID´s mitgeben? HTML, Usability und Barrierefreiheit 0 14.06.2005 10:55

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
eindeutige id vom bild, select where id vor zurück, php vor zurück unabhängig

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