Le modèle agrégé est une pierre angulaire de la conception axée sur le domaine (DDD), cruciale pour maintenir la cohérence des données et appliquer les règles métier dans les collections d'objets. Cet article explore les complexités de la mise en œuvre d'agrégats à l'aide de l'éloquente de Laravel, un modèle d'enregistrement actif.
Les meilleures pratiques architecturales préconisent la séparation du modèle de domaine des problèmes d'infrastructure. Cependant, un enregistrement actif, de par sa nature (emballage de lignes de base de données), couple étroitement le modèle de persistance, conduisant potentiellement à des conceptions complexes et erronées.
Prise des clés:
- Les agrégats sont centraux du DDD, garantissant la cohérence en regroupant des objets en une seule unité, régis par une racine agrégée. L'interaction externe est uniquement à travers cette racine.
- Le couplage inhérent à l'enregistrement actif à la persistance rend le découplage difficile, augmentant la complexité lorsqu'il est utilisé avec des agrégats.
- La mise en œuvre d'agrégats avec un enregistrement actif est réalisable mais difficile. Le traitement des objets d'enregistrement actifs comme les objets traditionnels peut conduire à un code désordonné.
- L'enregistrement actif excelle dans le développement rapide des applications (RAD), mais ses compromis le rendent moins adapté à la modélisation des agrégats complexes.
Comprendre les agrégats:
Un agrégat est un groupe d'objets agissant comme une seule unité, avec un objet désigné comme racine agrégée. Toutes les interactions externes doivent passer par la racine, qui gère la cohérence des objets dans sa frontière. Les limites agrégées définissent les lunettes de transaction; Un seul agrégat peut être engagé par transaction. Les modifications aux autres agrégats nécessitent une cohérence éventuelle.
Vaughn Vernon "Implémentation de la conception axée sur le domaine" décrit les principaux principes de conception agrégés:
- Protéger les invariants dans les limites de cohérence.
- Concevoir de petits agrégats.
- Référencer les autres agrégats par identité uniquement.
- Utiliser une cohérence éventuelle en dehors de la frontière.
Un exemple de blog:
Modérons un article de blog. Post
est une racine agrégée appropriée, avec Title
et Copy
comme objets de valeur. Author
reste en dehors de la frontière, référencée par ID. Comment
est une entité au sein de l'agrégat Post
. Les agrégats trop importants ont un impact sur les performances; Gardez-les petit et bien défini.
une classe Post
simplifiée (sans éloquent):
final class Post { // ... properties and methods ... public function comment(Message $message) { if ($this->locked->isLocked()) { throw new PostIsLocked; } // ... add comment ... } }
Intégration éloquente:
Maintenant, incorporons éloquents:
final class Post extends Eloquent { // ... methods ... public function comments() { return $this->hasMany(Comment::class); } // ... accessors and mutators for Value Objects ... }
Eloquent simplifie le code en gérant les propriétés en interne. Cependant, cela passe à l'orientation du comportement aux données, ce qui conduit potentiellement à des modèles de domaine anémique. La méthode comments()
facilite les relations d'Elogent.
relever les défis:
- Données par rapport au comportement: L'accès direct des données d'Eloquent peut inciter les développeurs à contourner le comportement de la racine globale, compromettant l'application des règles commerciales. Utilisez toujours le Tell, ne demandez pas le principe.
- Objets de valeur: Les accessoires et mutateurs d'Eloquent aident à gérer les objets de valeur, en maintenant l'intégrité des données.
- invariants: Le constructeur d'Eloquent empêche l'application invariante à la création d'objets. Utilisez des méthodes d'usine ou des constructeurs nommés dans la racine agrégée ou une classe connexe pour l'atténuer. Cependant, cela se heurte aux méthodes statiques existantes d'Eloquent.
- Relations: L'accès directement à des relations contourne la racine globale, sapant l'application des règles commerciales. Encapsuler la gestion des relations dans la racine agrégée.
Conclusion:
Bien que possible, la modélisation d'agrégats avec éloquente présente des défis importants. L'accent mis par le modèle d'enregistrement actif sur les données entre en conflit avec la nature orientée objet des agrégats. Le choix dépend des besoins et des priorités du projet. La vitesse des enregistrements actifs est bénéfique pour RAD, mais pour les domaines complexes, les compromis pourraient l'emporter sur les avantages. Une attention particulière et une approche disciplinée sont essentielles lors de la combinaison des principes DDD avec des orms enregistrés actifs.
FAQS (Adressant les FAQ fournies):
Les FAQ fournies sont adéquatement abordées dans la réponse révisée ci-dessus. Les explications des agrégats, des objets de valeur, des mutateurs et les défis de les utiliser avec éloquent sont intégrés dans le texte principal pour un meilleur flux et une meilleure clarté.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Laravel simplifie la gestion des données de session temporaires à l'aide de ses méthodes de flash intuitives. Ceci est parfait pour afficher de brefs messages, alertes ou notifications dans votre application. Les données ne persistent que pour la demande ultérieure par défaut: $ demande-

L'extension PHP Client URL (CURL) est un outil puissant pour les développeurs, permettant une interaction transparente avec des serveurs distants et des API REST. En tirant parti de Libcurl, une bibliothèque de transfert de fichiers multi-protocol très respectée, PHP Curl facilite Efficient Execu

La journalisation PHP est essentielle pour surveiller et déboguer les applications Web, ainsi que pour capturer des événements critiques, des erreurs et un comportement d'exécution. Il fournit des informations précieuses sur les performances du système, aide à identifier les problèmes et prend en charge le dépannage plus rapide

Laravel fournit une syntaxe de simulation de réponse HTTP concise, simplifiant les tests d'interaction HTTP. Cette approche réduit considérablement la redondance du code tout en rendant votre simulation de test plus intuitive. L'implémentation de base fournit une variété de raccourcis de type de réponse: Utiliser illuminate \ support \ faades \ http; Http :: faux ([[ 'google.com' => 'Hello World', 'github.com' => ['foo' => 'bar'], 'forge.laravel.com' =>

Voulez-vous fournir des solutions instantanées en temps réel aux problèmes les plus pressants de vos clients? Le chat en direct vous permet d'avoir des conversations en temps réel avec les clients et de résoudre leurs problèmes instantanément. Il vous permet de fournir un service plus rapide à votre personnalité

L'article traite de la liaison statique tardive (LSB) dans PHP, introduite dans PHP 5.3, permettant une résolution d'exécution de la méthode statique nécessite un héritage plus flexible. Problème main: LSB vs polymorphisme traditionnel; Applications pratiques de LSB et perfo potentiel

L'article examine l'ajout de fonctionnalités personnalisées aux cadres, en se concentrant sur la compréhension de l'architecture, l'identification des points d'extension et les meilleures pratiques pour l'intégration et le débogage.

Alipay Php ...


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

PhpStorm version Mac
Le dernier (2018.2.1) outil de développement intégré PHP professionnel

Version Mac de WebStorm
Outils de développement JavaScript utiles

ZendStudio 13.5.1 Mac
Puissant environnement de développement intégré PHP

MinGW - GNU minimaliste pour Windows
Ce projet est en cours de migration vers osdn.net/projects/mingw, vous pouvez continuer à nous suivre là-bas. MinGW : un port Windows natif de GNU Compiler Collection (GCC), des bibliothèques d'importation et des fichiers d'en-tête librement distribuables pour la création d'applications Windows natives ; inclut des extensions du runtime MSVC pour prendre en charge la fonctionnalité C99. Tous les logiciels MinGW peuvent fonctionner sur les plates-formes Windows 64 bits.