Ik ben bezig met het schrijven van een PHP-class voor het maken/verwerken van een boomstuctuur, opgeslagen in mysql.
Hier bij maak ik gebruik van een zgn. Modified Preorder Tree Traversal - constructie (ik kon er niks overvinden op got, ik vraag me af of er veel mensen zijn die dit kennen
)
Een groot voordeel hiervan is dat je niet te maken hebt met recursie, wat ik probber te vermijden.
Nadeel is dat bij het aanpassen van de boom er veel waardes geupdate moeten worden waardoor het programeren vrij ingewikkeld wordt (vandaar mijn poging tot deze class)
Ik ben al een heel eind, ik heb al methodes voor het toevoegen, verwijderen en verwisselen van nodes, het verkrijgen van het path van de root naar een node en het 'tekenen' van de boom
het probleem ligt bij het verplaatsen van nodes. Ik zit hier al 2 dagen op te ploeteren, maar ik loop nu echt vast en kom ten einde raad hier hulp zoeken
Hier onder wat ik totnutoe heb:
In de meeste gevallen werkt dit zoals het hoort, het probleem ligt vooral bij het uitsluiten van nodes die niet geupdate hoeven te/mogen worden.
Nu worden de nodes die links van de destination-node, maar wel in dezelfde tak liggen ook geupdate; deze moeten uitgesloten worden.
Ik vraag me af of het zo duidlijk is
maar toch maar een poging:
Zijn er hier mensen die een oplossing/voorbeeld script hebben. Of weet iemand een goede manier om dit probleem aan te pakken want ik zie door de bomen het bos niet meer
Hier bij maak ik gebruik van een zgn. Modified Preorder Tree Traversal - constructie (ik kon er niks overvinden op got, ik vraag me af of er veel mensen zijn die dit kennen
Een groot voordeel hiervan is dat je niet te maken hebt met recursie, wat ik probber te vermijden.
Nadeel is dat bij het aanpassen van de boom er veel waardes geupdate moeten worden waardoor het programeren vrij ingewikkeld wordt (vandaar mijn poging tot deze class)
Ik ben al een heel eind, ik heb al methodes voor het toevoegen, verwijderen en verwisselen van nodes, het verkrijgen van het path van de root naar een node en het 'tekenen' van de boom
het probleem ligt bij het verplaatsen van nodes. Ik zit hier al 2 dagen op te ploeteren, maar ik loop nu echt vast en kom ten einde raad hier hulp zoeken
Hier onder wat ik totnutoe heb:
PHP:
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
| function moveNode ($srcnode, $dstnode) { $src = $this->getNodeInfo ($srcnode); $dst = $this->getNodeInfo ($dstnode); if (!$src && !$dst) return false; if ($srcnode == $dstnode || ($dst[$this->getCol('LFT')] >= $src[$this->getCol('LFT')] and $dst[$this->getCol('LFT')] <= $src[$this->getCol('RGT')]) || $src[$this->getCol('PID')] == $dstnode) { return false; } $pts = $this->getPath ($srcnode, $this->getCol('NID').', '.$this->getCol('LFT').', '.$this->getCol('RGT')); $ptd = $this->getPath ($dstnode, $this->getCol('NID').', '.$this->getCol('LFT').', '.$this->getCol('RGT')); $key=0; while ($pts[$key][$this->getCol('NID')] == $ptd[$key][$this->getCol('NID')]) $key++; $limit1 = (!$pts[$key][$this->getCol('NID')])?$pts[$key-1]:$pts[$key]; $limit2 = (!$ptd[$key][$this->getCol('NID')])?$ptd[$key-1]:$ptd[$key]; $lftlimit = min ($limit1[$this->getCol('LFT')], $limit1[$this->getCol('RGT')], $limit2[$this->getCol('LFT')], $limit2[$this->getCol('RGT')]); $rgtlimit = max ($limit1[$this->getCol('LFT')], $limit1[$this->getCol('RGT')], $limit2[$this->getCol('LFT')], $limit2[$this->getCol('RGT')]); if ($dst[$this->getCol('LFT')] < $src[$this->getCol('LFT')]) { //leftmove $tomove = $src[$this->getCol('LFT')]-$dst[$this->getCol('LFT')]-1; $moving = $src[$this->getCol('RGT')]-$src[$this->getCol('LFT')]+1; $sql = 'UPDATE ' . $this->getTreeTable(). ' '; $sql.= 'SET '; // (...) regel voor het updaten van de level van de node, deze werkt $sql.= $this->getCol('LFT').' = IF('.$this->getCol('LFT').' <= '.$dst[$this->getCol('LFT')].', '; $sql.= $this->getCol('LFT').', '; $sql.= 'IF('.$this->getCol('LFT').' >= '.$src[$this->getCol('LFT')].', '; $sql.= $this->getCol('LFT').'-'.$tomove.', '; $sql.= $this->getCol('LFT').'+'.$moving.')), '; $sql.= $this->getCol('RGT').' = IF('.$this->getCol('RGT').' > '.$src[$this->getCol('RGT')].', '; $sql.= $this->getCol('RGT').', '; $sql.= 'IF('.$this->getCol('RGT').' > '.$src[$this->getCol('LFT')].', '; $sql.= $this->getCol('RGT').'-'.$tomove.', '; $sql.= $this->getCol('RGT').'+'.$moving.')) '; $sql.= 'WHERE '; $sql.= $this->getCol('LFT').' BETWEEN '.$lftlimit.' AND '.$rgtlimit; } else { #right //bij een rightmove heb k nog geen problemen gevonden. } $sql2 = 'UPDATE ' . $this->getTreeTable(). ' '; $sql2.= 'SET '; $sql2.= $this->getCol('PID').' = '.$dst[$this->getCol('NID')].' '; $sql2.= 'WHERE '; $sql2.= $this->getCol('NID').' = '.$src[$this->getCol('NID')]; $this->DB->runQuery ( $sql2 ); return $this->DB->runQuery ( $sql ); //echo $sql; } |

In de meeste gevallen werkt dit zoals het hoort, het probleem ligt vooral bij het uitsluiten van nodes die niet geupdate hoeven te/mogen worden.
Nu worden de nodes die links van de destination-node, maar wel in dezelfde tak liggen ook geupdate; deze moeten uitgesloten worden.
Ik vraag me af of het zo duidlijk is
Zijn er hier mensen die een oplossing/voorbeeld script hebben. Of weet iemand een goede manier om dit probleem aan te pakken want ik zie door de bomen het bos niet meer

[ Voor 21% gewijzigd door Verwijderd op 18-05-2004 22:39 ]