Meine Datenbank/table jeder Endpunkt/Umfang mehrere Tabellen haben,
zB Benutzer: Benutzer, user_information, user_role ...
Ich frage mich, sollte ich Tabelle trennen wie unten, oder nicht?Datenbankentwurf. Und bekommen Zeitpunkt der letzten Änderung mit jeder Spalte in PostgreSQL
Dies ist mein erstes Mal, ein Produkt zu bauen, das nicht wie vorher nur eine einmalige Arbeit kleine Website machen. und das könnte weitere Funktionen in der zukünftigen Version hinzufügen.
Ich bin mir nicht sicher über dieses Überdesign? Hilft separate Tabelle wie diese in Zukunft?
und Nachteile, die ich kenne, ist mehr Tabellenbeitritt verwenden, und schwieriger für mich, um die Abfrage zu erstellen.
jeder Vorschlag, teilen Erfahrung wird wirklich zu schätzen wissen.
Für jetzt kann ich nur vorstellen, ich möchte jede Spalte zuletzt geändert Zeit wissen?
Also, wenn ich jede Spalte zuletzt geänderte Zeit wissen möchte, gibt es irgendeine ursprüngliche Build-Methode in PostgreSQL? oder ich habe für jede Spalte wie email_last_modified_date
, username_last_modified_date
...
Endpunkt/scope Benutzer
CREATE TABLE IF NOT EXISTS "user"(
"id" SERIAL NOT NULL,
"create_date" timestamp without time zone NOT NULL,
"last_modified_date" timestamp without time zone,
"last_modified_by_user_id" integer,
"status" integer NOT NULL,
PRIMARY KEY ("id")
);
CREATE TABLE IF NOT EXISTS "user_information"(
"id" SERIAL NOT NULL,
"create_date" timestamp without time zone NOT NULL,
"last_modified_date" timestamp without time zone,
"last_modified_by_user_id" integer,
"user_id" integer NOT NULL,
"email" varchar(100) NOT NULL,
"username" varchar(50),
"password" varchar NOT NULL,
"first_name" varchar(50),
"last_name" varchar(50),
"website" varchar,
"description" varchar,
"birth_date" timestamp without time zone,
"country" varchar(50),
"gender" integer,
"file_type" integer,
"file_name" varchar(50),
"file_extension" varchar(50),
"file_portrait" boolean,
PRIMARY KEY ("id"),
FOREIGN KEY ("user_id") REFERENCES "user" ("id") ON DELETE CASCADE ON UPDATE CASCADE
);
CREATE TABLE IF NOT EXISTS "user_role"(
"id" SERIAL NOT NULL,
"create_date" timestamp without time zone NOT NULL,
"last_modified_date" timestamp without time zone,
"last_modified_by_user_id" integer,
"user_id" integer NOT NULL,
"role" integer NOT NULL,
PRIMARY KEY ("id"),
FOREIGN KEY ("user_id") REFERENCES "user" ("id") ON DELETE CASCADE ON UPDATE CASCADE
);
merge Tabelle hinzufügen?
CREATE TABLE IF NOT EXISTS "user"(
"id" SERIAL NOT NULL,
"create_date" timestamp without time zone NOT NULL,
"last_modified_date" timestamp without time zone,
"last_modified_by_user_id" integer,
"status" integer NOT NULL,
"information_last_modified_date" timestamp without time zone,
"information_last_modified_by_user_id" integer,
.... user_information
"role_last_modified_date" timestamp without time zone,
"role_last_modified_by_user_id" integer,
... user_role
PRIMARY KEY ("id")
);
Danke für die Antwort! Was ist Event-Sourcing? meinst du das https://msdn.microsoft.com/en-us/library/dn589792.aspx? – user1775888
@ user1775888: ja das Gleiche. –
Ich benutze PostgreSQL mit nodejs, und ich fand diese https://www.npmjs.com/package/eventstore, tut Event Sourcing bedeutet, es auf PostgreSQL-Ereignis auslösen, aber ich muss noch Daten in der Datenbank speichern? – user1775888