2009-07-14 7 views
8

Ich bin auf einer Web-Anwendung arbeiten, die eine gehostete, Multi-User-Lösung sein werden, wenn es fertig ist. Ich versuche herauszufinden, wie ich das Datenbankdesign für meine App am besten handhaben kann. Insbesondere muss ich herausfinden, wie mehrere separate Konten verwaltet werden.Multi-User Web Application Datenbank-Design

So wie ich es sehe, gibt es ein paar Optionen: 1) Gibt einen Satz von Datenbanktabellen. Fügen Sie in jeder Tabelle eine Benutzerspalte oder etwas Ähnliches ein, die jede Zeile dem richtigen Benutzerkonto zuordnen. 2) Erstellen Sie eine völlig separate Datenbank für jeden Benutzer. Aus Performance-Gründen scheint das keine besonders gute Idee zu sein. 3) Erstellen Sie ein separates Schema für jeden Benutzer in einer einzelnen Datenbank. Jedes Schema enthält die Tabellen für jeden Benutzer.

Wie würden Sie dieses Problem umgehen? Gibt es eine Option, die ich vermisse? Ich verwende PostgreSQL als meine Datenbank, wenn das einen Unterschied macht, wie Sie mit diesem Problem umgehen.

+0

mögliches Duplikat von [Ist es nicht sinnvoll, jedem Benutzer auf meiner Site eine MySQL-Datenbank zuzuordnen?] (Http://stackoverflow.com/q/327787/90527). – outis

Antwort

6

Ich habe fast immer mit der Option # 1 weg. Wenn Sie es richtig gestalten, benötigen Sie möglicherweise nur Ihre Benutzerspalte in einigen Schlüsseltabellen, die Ihr Einstiegspunkt sind, und dann kann alles andere aus diesen Schlüsseltabellen herausgeführt werden.

5

Als allgemeine Faustregel möchten Sie praktisch nie mehrere Tabellen (oder Datenbanken) mit identischen Strukturen haben. Wenn Sie die Erstellung separater Tabellen stuff_for_user_a und stuff_for_user_b erwägen (was Ihre Optionen # 2 und # 3 sehr klingen), dann möchten Sie wahrscheinlich nur eine stuff Tabelle erstellen, die eine user Spalte enthält (dh Ihre Option # 1).