php-resource



Zurück   PHP-Scripte PHP-Tutorials PHP-Jobs und vieles mehr > Entwicklung > SQL / Datenbanken
 

Login

 
eingeloggt bleiben
star Jetzt registrieren   star Passwort vergessen
 

 

 


SQL / Datenbanken Probleme mit SQL? Hier könnt ihr eure Fragen zu SQL (MySQL, PostgreSQL, MS-SQL und andere ANSI-SQL Server) los werden.

Antwort
 
LinkBack Themen-Optionen Thema bewerten
  #1 (permalink)  
Alt 29-05-2008, 13:06
webdream
 Registrierter Benutzer
Links : Onlinestatus : webdream ist offline
Registriert seit: Jan 2008
Beiträge: 94
webdream ist zur Zeit noch ein unbeschriebenes Blatt
Standard NestedSetBaum - Unterbäume auslesen

Hallo Board!
Ich nutze die NestedSetBaum Klasse von Martin Rosekeit. Der Aufbau der Tabelle sieht so aus:
`id` int(10) unsigned NOT NULL auto_increment,
`lft` int(10) unsigned NOT NULL default '0',
`rgt` int(10) unsigned NOT NULL default '0',
`moved` int(1) unsigned NOT NULL default '0',
`titel` varchar(255) NOT NULL default '',


Die gesamte Struktur frage ich z.B. so ab:
PHP-Code:
<?php
$sql 
"SELECT group2.*,
COUNT(*) AS level
FROM xxx AS group1,
xxx AS group2
WHERE group2.lft BETWEEN group1.lft AND group1.rgt
GROUP BY group2.lft"
;  
$result mysql_query($sql) OR die(mysql_error());        
while(
$row mysql_fetch_assoc($result)) 
{  
$KategorieID=$row['id'];
$KategorieLevel=$row['level'];
$KategorieTitel=$row['titel'];
$space str_repeat ("&nbsp;&nbsp;","$KategorieLevel");
echo 
"<a href=test.php?ID=$KategorieID>" $space "$KategorieTitel</a><br>"
}
?>
Das klappt auch wunderbar.
Jetzt möchte ich aber NUR die Unterbäume eine einzigen Kategorie auf einer extra "Kategoriedetailseite" darstellen.
Wie mach ich das?

Beispiel einer komplett Ausgabe des Baums
Code:
- Home
--- Produktgruppe1
--- Produktgruppe2
----- ProduktA
----- ProduktB
----- ProduktC
----- ProduktD
--- Produktgruppe3
----- ProduktG
--- Produktgruppe4
----- ProduktX
----- ProduktY
----- ProduktZ
Beispiel für die Ausgabe der Unterkategorie 2
Code:
--- Produktgruppe2
----- ProduktA
----- ProduktB
----- ProduktC
----- ProduktD
Besten Dank!
Mit Zitat antworten
  #2 (permalink)  
Alt 29-05-2008, 13:10
jahlives
 Master
Links : Onlinestatus : jahlives ist offline
Registriert seit: Jun 2004
Ort: Hooker in Kernel
Beiträge: 8.279
jahlives ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Alles was zwischen lft und rgt des Elternelements liegt gehört zu deinem gesuchten Teilbaum. Ich verwende dazu jeweils noch eine Funktion um die lft und rgt Werte des Elternelements festzustellen. Mit diesen beiden Werten passt du deine Abfrage dementsprechend an

http://www.klempert.de/nested_sets/artikel/#kap4
http://dev.mysql.com/tech-resources/...ical-data.html
__________________
Gutes Tutorial | PHP Manual | MySql Manual | PHP FAQ | Apache | Suchfunktion für eigene Seiten

"An error does not become truth by reason of multiplied propagation, nor does truth become error because nobody sees it."
Mohandas Karamchand Gandhi (Mahatma Gandhi) (Source)
Mit Zitat antworten
  #3 (permalink)  
Alt 29-05-2008, 13:10
TobiaZ
  Moderator
Links : Onlinestatus : TobiaZ ist offline
Registriert seit: Jan 2001
Ort: MUC und MGL, Germany
Beiträge: 34.421
Blog-Einträge: 1
TobiaZ befindet sich auf einem aufstrebenden Ast
Standard

WHERE left > [linkswert der Kategorie] AND right < [rechtswert d. K.]
__________________
ERST LESEN: Unsere Regeln. | Ich hab schon Pferde kotzen sehn!

READ THIS: Strings richtig trennen/verbinden | JOINs, das leidige Thema | Wegwerf E-Mail Adressen

Ich werde keinen privaten 1:1 Support leisten, außer ich biete ihn ausdrücklich an.

Wenn man sich selbst als "Noob" bezeichnet, sollte man die Finger davon lassen.
Wenn man gewillt ist daran etwas zu ändern, lernt man Grundlagen!
Mit Zitat antworten
  #4 (permalink)  
Alt 29-05-2008, 13:19
webdream
 Registrierter Benutzer
Links : Onlinestatus : webdream ist offline
Registriert seit: Jan 2008
Beiträge: 94
webdream ist zur Zeit noch ein unbeschriebenes Blatt
Standard

Perfekt. Danke!
Mit Zitat antworten
Antwort

Lesezeichen


Aktive Benutzer in diesem Thema: 1 (Registrierte Benutzer: 0, Gäste: 1)
 

Themen-Optionen
Thema bewerten
Thema bewerten:

Forumregeln
Es ist Ihnen nicht erlaubt, neue Themen zu verfassen.
Es ist Ihnen nicht erlaubt, auf Beiträge zu antworten.
Es ist Ihnen nicht erlaubt, Anhänge hochzuladen.
Es ist Ihnen nicht erlaubt, Ihre 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


PHP News

Die RIGID-FLEX-Technologie
Die RIGID-FLEX-TechnologieDie sogenannte "Flexible Elektronik" , oftmals auch als "Flexible Schaltungen" bezeichnet, ist eine zeitgemäße Technologie zum Montieren von elektronischen Schaltungen.

06.12.2018 | Berni

ebiz-trader 7.5.0 mit PHP7 Unterstützung veröffentlicht
ebiz-trader 7.5.0 mit PHP7 Unterstützung veröffentlichtDie bekannte Marktplatzsoftware ebiz-trader ist in der Version 7.5.0 veröffentlicht worden.

28.05.2018 | Berni


 

Aktuelle PHP Scripte

EJS TreeGrid ansehen EJS TreeGrid

EJS TreeGrid is DHTML component written in pure JavaScript to display and edit data in table, grid, tree view or grid with tree on HTML page

09.04.2019 coqsoft@ | Kategorie: JAVASCRIPT/ Components
Suchmaschine redaktionell, Branchenportal zum Geld verdienen

Programmbeschreibung Die Bezahl-Suchmaschine ist in Perl und PHP programmiert (eigenes CGI-Verzeichnis notwendig), benötigt PHP aber keine MySQL-Datenbank. Webmaster haben mit dieser Suchmaschine neben der normalen kostenlosen Registrierung von Lin

06.04.2019 skripte@ | Kategorie: PHP/ Suchmaschinen
Oog Photo-Video-Gallery

Mit Oog Photo-Gallery können Sie einfach und stilvoll Bilder (auch Video & Audio) auf Ihrem PHP5-Webserver veröffentlichen und verwalten. Lizenz: GNU GPL v2

06.04.2019 trottbrand@ | Kategorie: PHP/ Bilder
 Alle PHP Scripte anzeigen

Alle Zeitangaben in WEZ +2. Es ist jetzt 15:50 Uhr.