Ich habe einige Zweifel darüber, wie DDD-Ansatz im realen Projekt zu verwenden.Groß gesagt, in meiner App habe ich zwei Arten von Operationen: einfache CRUD-Operation, die recht einfach ist, nur erstellen oder aktualisieren Datensätze in der DB und benötigen keine Viele Geschäftslogik und einige Operationen, die es erfordern. Für beide Arten von Betrieb verwende ich Dienste, um eine Art von "Asymmetrie" zu vermeiden, aber für CRUD-Operationen sieht es aus wie Overhead, weil ich nur save() -Methode in Service-Methode wrap und es ist keine Logik hinzufügen.Wie verwende ich DDD in der Praxis?
Also was ist der beste Ansatz nach Ihrer Erfahrung machen einfache (CRUD) Betrieb in Controllern oder setzen Sie es in Dienstleistungen oder haben Sie vielleicht noch andere Ideen?
Haben Sie Ihre beschränkten Kontexte, Aggregate identifiziert? Was meinst du, wenn du DDD erwähnst? –
Für die CRUD-Architektur sollten Sie die Dinge so einfach wie möglich halten, ohne viele unnötige Ebenen. Für die andere komplexere Anwendung könnten Sie DDD anwenden: identifizieren Sie beschränkte Kontexte, Aggregate, Entitäten, Wertobjekte. Abhängig von der Komplexität und den Geschäftsanforderungen (Skalierbarkeit, Wartbarkeit, Anzahl der Benutzer usw.) wählen Sie eine High-Level-Architektur (Onion Architecture/Ports and Adapters) und eine Low-Level-Architektur (CQRS) –
DDD ist ein Ansatz zur Handhabung komplexer Domänen . In deinem Fall klingt es nicht so, als würdest du es brauchen. Check out Vaughn Vernon Score-Karte: http://www.informit.com/articles/article.aspx?p=1944876&seqNum=2 – nova