php.de

Zurück   php.de > php.de Intern > Off-Topic Diskussionen

Off-Topic Diskussionen Mach mal Pause vom Programmieren!

Antwort
 
LinkBack Themen-Optionen Bewertung: Bewertung: 1 Stimmen, 5,00 durchschnittlich.
Alt 12.05.2011, 15:08  
Benutzer
 
Registriert seit: 23.03.2011
Beiträge: 30
PHP-Kenntnisse:
Anfänger
Wolf66 befindet sich auf einem aufstrebenden Ast
Standard Forensystem, wie funktionierts?

Hallo.

Mich würde mal interessieren, wie ein gutes Forensystem funktioniert.

-Speicherung der Beiträge in Baumstruktur, und nicht als "Faden". Ähnlich wie bei Newsgroups.


Wie funktioniert sowas? Wird in jedem Beitrag dann eine "Parent-ID" und eine "Thread ID" eingetragen und der Aufbau erfolgt von "Unten nach oben"?

Signaturen und Username etc: Werden diese Sachen beim Erstellen in die Message kopiert oder werden diese Sachen beim Anzeigen per DB Query erst eingefügt?
Wolf66 ist offline   Mit Zitat antworten
Sponsor Mitteilung
PHP Code Flüsterer

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

Alt 12.05.2011, 15:30  
Moderator
 
Benutzerbild von Asipak
 
Registriert seit: 18.07.2005
Beiträge: 4.072
Asipak sorgt für eine eindrucksvolle AtmosphäreAsipak sorgt für eine eindrucksvolle Atmosphäre
Standard

Zitat:
Wie funktioniert sowas? Wird in jedem Beitrag dann eine "Parent-ID" und eine "Thread ID" eingetragen und der Aufbau erfolgt von "Unten nach oben"?
Um eine Baumstruktur zu realisieren, bräuchte man schon so etwas wie eine Parent-ID. Was meinst du mit „von unten nach oben“? Eine Sortierung kann man nach unterschiedlichen Kritierien durchführen, beispielsweise nach dem Datum. Oder man erstellt eine separate Spalte in der Datenbank, die ausschließlich für die Sortierung zuständig ist.
Zitat:
Signaturen und Username etc: Werden diese Sachen beim Erstellen in die Message kopiert oder werden diese Sachen beim Anzeigen per DB Query erst eingefügt?
Das kann man sich selbst beantworten, indem man sich fragt, was passiert, wenn der User seine Signatur ändert.
Asipak ist offline   Mit Zitat antworten
Alt 12.05.2011, 15:31  
Erfahrener Benutzer
 
Registriert seit: 04.08.2010
Beiträge: 287
PHP-Kenntnisse:
Fortgeschritten
zwutz wird schon bald berühmt werden
Standard

kann man machen, wie man will.

wenn man die thread-id mitzieht hat man den Vorteil, dass man mit einer abfrage alle relevanten Beiträge hat. Die parent-id ist dann nur noch für die Darstellung relevant.

Sig und Username werden in der Regel erst am Ende eingefügt. So spart man sich den Platz in der DB und der User hat auch in alten Beiträgen seine aktuelle Sig. Der Benutzername sollte allein schon aus rechtlichen Gründen erst am Ende reinkommen, falls jemand seinen Namen löschen oder ändern lassen will
zwutz ist offline   Mit Zitat antworten
Alt 12.05.2011, 15:44  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

[MOD: verschoben]
__________________
--
One pixel is still too big. Please make it smaller. ASAP.

Initiative Mittelstand.
Die wichtigste Gestaltungsregel im Screendesign ist Pi mal Daumen des Arbeitgebers.
--
nikosch ist offline   Mit Zitat antworten
Alt 12.05.2011, 16:38  
Benutzer
 
Registriert seit: 23.03.2011
Beiträge: 30
PHP-Kenntnisse:
Anfänger
Wolf66 befindet sich auf einem aufstrebenden Ast
Standard

Ja, die "Thead-ID" braucht man, um alle Beiträge eines Threads zu finden, Anders wirds wohl relativ kompliziert.
Parent Id brächte man, um halt die typische Vorfahr-Nachfahr Struktur auf einfache Weise zu machen.
So stelle ich mir das jedenfalls vor.

Bei Username und Signatur:
Ich kenne Foren, da wirken sich Änderungen nur auf neue Beiträge aus. Ich kenne auch Foren, wo es sich auch auf alte Beiträge auswirkt.

Wenn man die Sachen erst zur Laufzeit per Query einfügt, hat man natürlich viele, viele Querys mehr, als wenn z.B. die Signatur jedes mal bei der Beitragserstelung fest einkopiert wird.
Dafür hat man mehr Speicherplatzverbrauch.
Wolf66 ist offline   Mit Zitat antworten
Alt 12.05.2011, 17:02  
Erfahrener Benutzer
 
Registriert seit: 07.12.2009
Beiträge: 843
PHP-Kenntnisse:
Fortgeschritten
chorn befindet sich auf einem aufstrebenden Ast
Standard

---
chorn ist offline   Mit Zitat antworten
Alt 12.05.2011, 17:29  
Erfahrener Benutzer
 
Benutzerbild von Dark Guardian
 
Registriert seit: 10.10.2009
Beiträge: 2.630
PHP-Kenntnisse:
Fortgeschritten
Dark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekanntDark Guardian ist jedem bekannt
Standard

Zitat:
Zitat von Wolf66 Beitrag anzeigen
Ja, die "Thead-ID" braucht man, um alle Beiträge eines Threads zu finden, Anders wirds wohl relativ kompliziert.
Parent Id brächte man, um halt die typische Vorfahr-Nachfahr Struktur auf einfache Weise zu machen.
So stelle ich mir das jedenfalls vor.
Nested Sets wären eine Alternative zur üblichen Baumstruktur mit ParentId und Rekursion. Die ThreadId brauchst du nicht. Ein Thread ist eigentlich nur ein Post mit ParentId 0. Alles was einen Thread sonst noch besonders amcht, wie z.B. letzter Beitrag o.Ä. lässt sich aus allen anderen Daten live ermitteln.

Um die Performance dadurch nicht zu sehr zu drücken sind entsprechende Caching Verfahren angebracht. Wie beispielsweiße das Zwischenspeichern des letzten Beitragsdatums um nur dafür nicht immer die Beitragshierarchie ablaufen zu müssen.

Dennoch kann das Speichern der ThreadId zum Post sinnvoll sein. Denn du sparst dir dann das Suchen innerhalb der Hierarchie und kann direkt auf bestimmte Posts zugreifen weil du immer weisst zu welchem Thread welcher Post gehört.

Außerdem kannst du, wie es jedes Forensystem mittlerweile kann, dann auch zwischen den Darstellungsformen wechseln.

Zitat:
Zitat von Wolf66 Beitrag anzeigen
Bei Username und Signatur:
Ich kenne Foren, da wirken sich Änderungen nur auf neue Beiträge aus. Ich kenne auch Foren, wo es sich auch auf alte Beiträge auswirkt.

Wenn man die Sachen erst zur Laufzeit per Query einfügt, hat man natürlich viele, viele Querys mehr, als wenn z.B. die Signatur jedes mal bei der Beitragserstelung fest einkopiert wird.
Trugschluss. Du musst sowieso für jeden Beitrag die Userid speichern und diese Daten aus der DB holen. Ob du nun noch ein Feld mehr ausliest oder nicht dürfte deine Performance nicht sonderlich nachhaltig beeinträchtigen.
__________________
"Alles im Universum funktioniert, wenn du nur weißt wie du es anwenden musst".

Geändert von Dark Guardian (12.05.2011 um 17:36 Uhr).
Dark Guardian ist offline   Mit Zitat antworten
Alt 12.05.2011, 17:32  
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

Zitat:
Um eine Baumstruktur zu realisieren, bräuchte man schon so etwas wie eine Parent-ID. Was meinst du mit „von unten nach oben“?
Schlechter weil lahmer und auf Dauer umständlicher Ansatz. Nested Sets sind besser. Wirken zwar anfangs komplizierter, stellen sich hinterher aber als effektiver, schneller und einfacher zu handhaben heraus.

Beitrag editiert:
[…] Zu lahm
__________________
Refining Linux Advent Calendar series “24 Outstanding ZSH Gems
Manko10 ist offline   Mit Zitat antworten
Alt 12.05.2011, 17:49  
poli-tik
Gast
 
Beiträge: n/a
Standard

Das Problem mit den parentIds ist, dass man nicht vernünftig SELECTs definieren kann. Man greift dann zu starren Strukturen und behindert sich dann nur selbst.

Möchte man flexibel bleiben und beliebig viele Ebenen definieren können, kann man das mit nested sets bewerkstelligen. Die haben jedoch einen großen Nachteil. Arbeitet man mit ihnen, ist das sehr arbeitsintensiv.

Im Forum gibt es einige Einträge zum Thema nested sets und Alternativen. Ich würde LDAP vorschlagen.
  Mit Zitat antworten
Alt 12.05.2011, 20:04  
moderatives Dielektrikum
 
Benutzerbild von nikosch
 
Registriert seit: 21.05.2008
Beiträge: 35.987
PHP-Kenntnisse:
Fortgeschritten
nikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunftnikosch hat eine strahlende Zukunft
Standard

Ich wage mal anzumerken, dass Threadstrukturen ja eigentlich (IMHO) auf Antwort/Zitatverhalten beruhen und Beiträge damit nicht zwingend nur einen parent-Node besitzen. Damit sind weder Nested Sets noch ParentID geeignet.
__________________
--
One pixel is still too big. Please make it smaller. ASAP.

Initiative Mittelstand.
Die wichtigste Gestaltungsregel im Screendesign ist Pi mal Daumen des Arbeitgebers.
--
nikosch 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
[Erledigt] HTTP Request: mit Java funktionierts, mit PHP nicht Thoresus PHP Tipps 2010 12 01.05.2010 23:47
Problem mit Forensystem Dominik PHP Tipps 2008 17 30.04.2008 14:28
warum funktionierts nicht im firefox? Dave Waterstone HTML, Usability und Barrierefreiheit 3 12.10.2006 01:02
mal funktionierts, mal nicht - großes Problem mit PHP Script nicobischof PHP Tipps 2005-2 5 01.10.2005 16:13
Suche einfaches Forensystem Madden Beitragsarchiv 5 10.08.2005 13:21
DELETE FROM... warum funktioniert's nicht? Calli PHP Tipps 2005-2 12 03.08.2005 11:55

Besucher kamen über folgende Suchanfragen bei Google auf diese Seite
laufzeit nested set, foren system

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