Ir al contenido principal

Patr贸n CQRS en C#: El arte de separar comandos y consultas 馃幁


Patr贸n CQRS en C#: El arte de separar comandos y consultas 馃幁

¡Imagina una biblioteca donde tienes libros que puedes leer y otros que puedes sacar y llevarte a casa! As铆 es como funciona el patr贸n CQRS en C#. Separa las operaciones de lectura (consultas) de las operaciones de escritura (comandos) para una arquitectura de software m谩s eficiente.



馃殌 Introducci贸n

El patr贸n CQRS (Command Query Responsibility Segregation) es un patr贸n de dise帽o que separa las responsabilidades de lectura y escritura en tu aplicaci贸n C#. Es como tener dos puertas separadas en tu casa: una para los invitados (consultas) y otra para el repartidor de pizzas (comandos).

馃挕 Conceptos B谩sicos

Comandos (Commands)

Estos son los que modifican el estado de tu sistema, como crear un nuevo usuario o actualizar un producto. Suelen representarse como m茅todos en tus controladores o servicios.

Consultas (Queries)

Las consultas recuperan datos sin modificar el estado del sistema. Pueden ser operaciones de solo lectura como obtener la lista de usuarios o recuperar detalles de un producto.

Controladores y Repositorios

Los controladores generalmente manejan comandos, mientras que los repositorios manejan consultas. Esto mantiene las responsabilidades separadas y hace que tu c贸digo sea m谩s f谩cil de mantener.

馃懆‍馃捇 Manos al C贸digo

Ejemplo 1: Crear un nuevo usuario (comando)


public async Task CreateUser([FromBody] CreateUserDto userDto)
{
    // ... Validaci贸n y mapeo del modelo
    var user = await _userService.CreateUserAsync(userDto);
    return Ok(user);
}
        

Este controlador maneja el comando de creaci贸n de usuario y llama al servicio de usuario para crear el usuario.

Ejemplo 2: Obtener la lista de usuarios (consulta)


public async Task GetUsers()
{
    // ...
    var users = await _userRepository.GetUsersAsync();
    return Ok(users);
}
        

Este controlador maneja la consulta para obtener la lista de usuarios y llama al repositorio de usuarios para recuperar los datos.

馃拵 Tips y Mejores Pr谩cticas

Tip #1: Mant茅n los comandos y consultas separados

Esto ayuda a evitar conflictos y hace que tu c贸digo sea m谩s f谩cil de entender y mantener.


// Controlador de comandos
public class UserController : ApiController
{
    // ...
}

// Controlador de consultas
public class UserQueryController : ApiController
{
    // ...
}
            

Tip #2: Usa nombres descriptivos

Nombra tus comandos y consultas de forma que describan claramente su prop贸sito. Esto mejora la legibilidad de tu c贸digo.

⚠️ Errores Comunes y Soluciones

Error #1: Mezclar comandos y consultas

Esto puede provocar conflictos y dificultar el mantenimiento de tu c贸digo.

Soluci贸n:

Mant茅n los comandos y consultas separados en diferentes m茅todos o incluso en diferentes clases.

馃幆 Conclusi贸n

El patr贸n CQRS en C# es una herramienta valiosa para dise帽ar aplicaciones escalables y mantenibles. Al separar las operaciones de lectura y escritura, puedes mejorar el rendimiento, reducir los conflictos y hacer que tu c贸digo sea m谩s f谩cil de entender.



Comentarios

Entradas populares de este blog

Gu铆a completa de .NET MAUI para el desarrollo de aplicaciones m贸viles multiplataforma

Gu铆a completa de .NET MAUI para el desarrollo de aplicaciones m贸viles multiplataforma ⏱️ Tiempo de lectura: 30 minutos 馃幆 Nivel: Intermedio ¡Prep谩rate para revolucionar el desarrollo m贸vil! Descubre .NET MAUI, el marco multiplataforma que te permite crear aplicaciones nativas para iOS, Android y escritorio con una sola base de c贸digo. Ad茅ntrate en los fundamentos, implementaciones pr谩cticas, ejemplos avanzados y mejores pr谩cticas para dominar .NET MAUI y llevar tus habilidades de desarrollo m贸vil al siguiente nivel. 馃搼 Contenido del Art铆culo Introducci贸n a .NET MAUI para m贸viles Fundamentos y Conceptos Clave Arquitectura de .NET MAUI ...

Eventos de una P谩gina Web (WebForm ASP.NET)

Este peque帽o post es para aclarar algunos conceptos sobre el ciclo de vida de una p谩gina web ASP.NET (WebForm). Nota: A este post le ir茅 agregando mas contenido poco a poco, con los propios comentarios de los lectores y mis experiencias diarias sobre el ciclo de vida y los distintos estados de una pagina. Eventos m谩s importantes de la pagina en orden de ejecuci贸n:     PreInit     Init     Load     PreRender PreInit El evento PreInit ocurre antes de la inicializaci贸n de los controles de la pagina. Normalmente es usado para a帽adir din谩micamente controles a la pagina, porque a帽adi茅ndolos aqu铆 garantizamos que a dichos controles se les apliquen adecuadamente los Skins del Theme definido (si no hemos definido ning煤n Theme dar铆a un poco igual a帽adirlos aqu铆 o en Init, por ejemplo). Adem谩s puede usarse para definir din谩micamente (program谩ticamente) la MasterPage y el Theme de la pagina. Init Este evento ocurre de...

馃敟 Microservicios con .NET: Gu铆a Definitiva para Principiantes y Desarrolladores Intermedios

馃敟 Microservicios con .NET: Gu铆a Definitiva para Principiantes y Desarrolladores Intermedios ⏱️ Tiempo de lectura: 15 minutos 馃幆 Nivel: Intermedio ¡Prep谩rate para sumergirte en el fascinante mundo de los microservicios con .NET! Esta gu铆a integral te equipar谩 con los conocimientos esenciales y las t茅cnicas pr谩cticas que necesitas para dominar esta arquitectura moderna. Tanto si eres un principiante que busca una base s贸lida como un desarrollador experimentado que busca ampliar tus habilidades, este art铆culo te guiar谩 paso a paso a trav茅s de los conceptos fundamentales, la implementaci贸n y los mejores pr谩cticas de los microservicios. 馃搼 Contenido del Art铆culo 馃殌 Introducci贸n a los Microservicios con .NET 馃挕 Fundamentos y Conceptos Clave ¿Qu茅 son los Microservicios? Ventajas de los Microservicios Desaf铆os de los Microservicios ...