when using domain driven design, is it better that your services' methods 开发者_如何学运维receive an entity as parameter or the id of your entity as parameter so that you can retrieve the entity inside the method using a repository?
for example:
public void Apply(Job job, User user)
versus
public void Apply(int jobId, int userId)
DDD is about mapping your client's vocabulary to your design. Your client (hopefully) talks about users applying for jobs, not some integer ID being linked to another integer ID. Try to stick to the real world as close as possible, unless it becomes a burden.
By passing in the entire entity, you can benefit from the entity's behavior immediately, without having to construct it first.
So stick to entities, unless you have a situation where you often only have an ID to work with. This usually happens when you're dealing with external systems, such as web services. In that case you can create a method overload that accepts the ID. This overload should validate the ID, construct the entity and call the overload that accepts the entity.
public void Apply(int jobId, int userId)
{
// Validate the IDs.
// Construct the entities.
var job = ...;
var user = ...;
// Call the 'proper' overload.
Apply(job, user);
}
public void Apply(Job job, User user)
{
// Actual business logic belongs here.
}
Again: try to avoid such overloads as much as possible, unless you're dealing with external systems that only return the ID.
From a coding point of view, entities are also better than integers. An integer can be of any integer value, so you'd have to validate it everywhere you use it. Your factories are responsible for constructing valid entities and your (domain) logic should keep your entities in a valid state. So using the entity is completely safe and shouldn't require much validation.
It depends on where your Application Service resides:
If your Service executes within the same AppDomain (i.e. you're calling it from the same executable), then passing the object is ideal. The Service can easily access other objects within the object graph.
If your Service executes in a different AppDomain (e.g. behind a WebService or other remote location), you should use an ID. The Service would then load the appropriate object from the persistence store before working with it.
If you try to send objects down the wire, you likely run into the problems described here.
Hope that helps.
If you send the object, you are creating dependency between the service and the entity. One of the advantages of using services is to act as facades to reduce dependency graph between classes and reduce the complexity of the design. It's better to use primitive types, structs, enums in service contracts but when dealing with large number of method parameters you may encapsulate them in an object but in this case it will be a DTO not an entity.
I use ViewModel for passing "flat entities" to/from application service. Also I use Document Message pattern to communicate with application service. In application service a use extension methods for business entities something like this:
public BusinessEntityViewModel ConvertToViewModel(this BusinessEntity businessEntity)
{
BusinessEntityViewModel bevm = new BusinessEntityViewModel{ Id = businessEntity.Id, ...}
return bevm;
}
In my understanding, difference is only the fact what does Domain do with User and Job to make "Apply" operation. If ID is quite enough, then it is ok to leave there only ID.
精彩评论