Sven Rautenberg: Wie löse ich dieses Problem am performantesten?

Beitrag lesen

Moin!

Angenommen da ist ein Schal.
Dieser Schal hat in der Datenbank in einer Tabelle die Id "200".
Dann würde ich für jedes Mitglied, die diesen Schal bewertet hat, folgendes in  eine seperate Tabelle schreiben:

id_der_bewertung Id_Der_Sache Mitglied_das_bewertet_hat

Aber wenn jedes mitglied z.b. 100 sachen bewertet, dann sind das 200.000 Datenbankeintragungen!

Ja und?

200.000 Datensätze sind doch ein Klacks für eine Datenbank. Erst recht, wenn vernünftig indiziert wird.

Viel unüerformanter wäre es, wenn du alle 100 Dinge, die ein Mitglied bewertet hat, in einem Cookie speicherst. Nur mal angenommen, jedes Ding würde aus einer vierstelligen ID bestehen, plus ein Trennzeichen, dann wären das 5 * 100 Zeichen = 500 Bytes extra, die der Client bei jedem Request immer wieder mitschickt und die der Server immer wieder mit auswerten muß. Das ist noch viel unschöner, zumal die Menge und Länge von Cookies begrenzt ist.

Dieses Forum hier speichert sich für jeden registrierten Benutzer, welche der mehreren tausend Postings auf der Startseite schon gelesen wurden. Ebenso erlaubt es benutzerdefinierte Markierungen von Postings als "interessant", merkt sich den Auf- und Zugeklappt-Status der einzelnen Threads, und bietet generell viele Anpassungsmöglichkeiten. Aber du wirst ja nicht behaupten, dass das Forum deswegen langsam ist.

- Sven Rautenberg

--
"Love your nation - respect the others."