34 | MediatR:轻松实现命令查询职责分离模式(CQRS)
实际上我们在定义我的查询的时候,也可以这样定义,例如我们定义一个 MyOrderQuery,把订单的所有名称都输出出去
namespace GeekTime.API.Application.Queries
{
public class MyOrderQuery : IRequest<List<string>>
{
public MyOrderQuery(string userName) => UserName = userName;
public string UserName { get; private set; }
}
}
我们再定义一个查询器,这里就可以从各种地方查询到我们的数据然后返回出去
namespace GeekTime.API.Application.Queries
{
public class MyOrderQueryHandler : IRequestHandler<MyOrderQuery, List<string>>
{
public Task<List<string>> Handle(MyOrderQuery request, CancellationToken cancellationToken)
{
return Task.FromResult(new List<string>());
}
}
}
实际上我们这样子就完成了查询和查询处理的定义
我们可以在 Controller 定义
[HttpGet]
public async Task<List<string>> QueryOrder([FromBody]MyOrderQuery myOrderQuery)
{
return await _mediator.Send(myOrderQuery);
}
这样就完成了查询和查询处理逻辑的分离
我们执行命令是同样的实现方式,我们这样子做的话可以将我们的查询的输入和处理定义在一个目录下面,也可以将我们的命令的定义和命令的执行放在一个目录下面,使我们的 Controller 关注于身份认证或者基础设施缓存等等一些逻辑的处理,它不再关心说我的业务逻辑是怎么样子的
相关文章
.NET Core开发实战(第34课:MediatR:轻松实现命令查询职责分离模式(CQRS))--学习笔记(上)
.NET Core开发实战(第33课:集成事件:使用RabbitMQ来实现EventBus)--学习笔记(下)
.NET Core开发实战(第33课:集成事件:使用RabbitMQ来实现EventBus)--学习笔记(上)
.NET Core开发实战(第32课:集成事件:解决跨微服务的最终一致性)--学习笔记
.NET Core开发实战(第31课:APIController:定义API的最佳实践)--学习笔记
.NET Core开发实战(第30课:领域事件:提升业务内聚,实现模块解耦)--学习笔记
.NET Core开发实战(第29课:定义仓储:使用EF Core实现仓储层)--学习笔记
.NET Core开发实战(第28课:工作单元模式(UnitOfWork):管理好你的事务)--学习笔记
.NET Core开发实战(第27课:定义Entity:区分领域模型的内在逻辑和外在行为)--学习笔记
.NET Core开发实战(第26课:工程结构概览:定义应用分层及依赖关系)--学习笔记
.NET Core开发实战(第25课:路由与终结点:如何规划好你的Web API)--学习笔记(下)
.NET Core开发实战(第25课:路由与终结点:如何规划好你的Web API)--学习笔记(上)
.NET Core开发实战(第24课:文件提供程序:让你可以将文件放在任何地方)--学习笔记
.NET Core开发实战(第23课:静态文件中间件:前后端分离开发合并部署骚操作)--学习笔记(下)
.NET Core开发实战(第23课:静态文件中间件:前后端分离开发合并部署骚操作)--学习笔记(上)
.NET Core开发实战(第22课:异常处理中间件:区分真异常与逻辑异常)--学习笔记(下)
.NET Core开发实战(第22课:异常处理中间件:区分真异常与逻辑异常)--学习笔记(上)
.NET Core开发实战(第21课:中间件:掌控请求处理过程的关键)--学习笔记(下)

本文分享自微信公众号 - DotNet NB(DotNetNB)。
如有侵权,请联系 support@oschina.cn 删除。
本文参与“OSC源创计划”,欢迎正在阅读的你也加入,一起分享。