CursosEmpresasBlogLiveConfPrecios

Creando modelo de tarea con Fluent API

Clase 15 de 25 • Curso de Fundamentos de Entity Framework

Clase anteriorSiguiente clase

Contenido del curso

Introducción
  • 1
    Bienvenida y presentación

    Bienvenida y presentación

    01:51
  • 2
    Prerrequisitos

    Prerrequisitos

    03:04
  • 3
    Conexión a base de datos

    Conexión a base de datos

    07:20
  • 4
    ¿Qué es un ORM en programación?

    ¿Qué es un ORM en programación?

    08:51
  • 5
    Introducción a Entity Framework

    Introducción a Entity Framework

    06:53
  • 6
    Creación de proyecto .NET con Entity Framework

    Creación de proyecto .NET con Entity Framework

    11:57
Iniciando con Entity Framework
  • 7
    Creación de modelos

    Creación de modelos

    08:28
  • 8
    Configuración de Entity Framework

    Configuración de Entity Framework

    06:53
  • 9
    Mapeo de modelos usando atributos

    Mapeo de modelos usando atributos

    09:52
  • 10
    Utilizando base de datos en memoria

    Utilizando base de datos en memoria

    10:13
  • 11
    Conectado a base de datos SQL server

    Conectado a base de datos SQL server

    10:53
  • 12
    Agregando conexión al archivo appsettings

    Agregando conexión al archivo appsettings

    07:28
Utilizando Fluent API
  • 13
    Introducción a Fluent API

    Introducción a Fluent API

    03:29
  • 14
    Creando modelo de categoría con Fluent API

    Creando modelo de categoría con Fluent API

    08:30
  • 15
    Creando modelo de tarea con Fluent API

    Creando modelo de tarea con Fluent API

    07:36
  • 16
    Conectado a base de datos con Fluent API

    Conectado a base de datos con Fluent API

    07:42
Migraciones
  • 17
    ¿Qué son las migraciones?

    ¿Qué son las migraciones?

    03:14
  • 18
    Inicializar las migraciones

    Inicializar las migraciones

    11:27
  • 19
    Creando una migración

    Creando una migración

    07:18
  • 20
    Agregando datos semilla

    Agregando datos semilla

    16:31
Consumo de datos
  • 21
    Obteniendo datos con Entity Framework

    Obteniendo datos con Entity Framework

    11:31
  • 22
    Guardando datos con Entity framework

    Guardando datos con Entity framework

    09:07
  • 23
    Actualizando datos con Entity framework

    Actualizando datos con Entity framework

    10:17
  • 24
    Eliminando datos con Entity framework

    Eliminando datos con Entity framework

    07:59
Cierre del curso
  • 25
    Continúa tu camino desarrollando

    Continúa tu camino desarrollando

    01:45
    rafael malanco velazquez

    rafael malanco velazquez

    student•
    hace 3 años
    codeenti.png
    Edinson Jesús Paternina Rivera

    Edinson Jesús Paternina Rivera

    student•
    hace 3 años

    Este Using que usamos para las anotaciones en el modelo ya no seria necesario: using System.ComponentModel.DataAnnotations.Schema;

    Kevin Castellano

    Kevin Castellano

    student•
    hace 3 años

    ¿Por qué no podría poner?

    tarea.Ignore(p => p.Resumen);
      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      Si es posible!

    Nicolas Guillen

    Nicolas Guillen

    student•
    hace 2 años

    El único problema que le veo a usar Fluent API es tener que actualizar el modelo y el contexto. Ahora por cada propiedad nueva, eliminada o modificada, hay que ir a context y hacer el cambio también. Depende del caso de uso pero para aplicaciones pequeñas yo sólo usaría DataAnnotations, y sólo usaría Fluent API en caso de ser necesario.

      David Santiago

      David Santiago

      student•
      hace 6 meses

      📌 No necesitas editar el DbContext cada vez que usas Fluent API.

      Usa IEntityTypeConfiguration<T> para separar la lógica:

      csharpCopiarEditarpublic class PersonaConfig : IEntityTypeConfiguration<Persona> { public void Configure(EntityTypeBuilder<Persona> builder) { builder.Property(p => p.Nombre).HasMaxLength(100); } }

      Y en el DbContext:

      csharpCopiarEditarprotected override void OnModelCreating(ModelBuilder modelBuilder) { modelBuilder.ApplyConfiguration(new PersonaConfig()); }

      ✅ Así el modelo queda limpio, y no repites nada en el DbContext. ✔ Fluent API sin dolor.

    Juan Betancur

    Juan Betancur

    student•
    hace 3 años

    Come se haría una relación de recurrencias?

      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      Te refieres a una relación de muchos a muchos? de ese ya tenemos una respuesta

      Este es un ejemplo de N:N, en lugar de poner WithMany usar WithOne:

      modelBuilder.Entity<Author>() .HasOne(a => a.Biography) .WithOne(b => b.Author) .HasForeignKey<AuthorBiography>(b => b.AuthorRef);

      Este seria un ejemplo de muchos con muchos: modelBuilder.Entity<BookCategory>() .HasKey(bc => new { bc.BookId, bc.CategoryId }); modelBuilder.Entity<BookCategory>() .HasOne(bc => bc.Book) .WithMany(b => b.BookCategories) .HasForeignKey(bc => bc.BookId); modelBuilder.Entity<BookCategory>() .HasOne(bc => bc.Category) .WithMany(c => c.BookCategories) .HasForeignKey(bc => bc.CategoryId);

      Para mas info te recomiendo este sitio: https://www.learnentityframeworkcore.com/configuration/many-to-many-relationship-configuration

    Marcos Lanuza

    Marcos Lanuza

    student•
    hace 3 años

    ¿Qué pasa con el mapeo de las propiedades virtuales? En este caso, la propiedad categoría dentro de Tarea. Esa puedo asumir que se mapea utilizando la llave foránea, verdad?

      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      Correcto, si se coloca como Virtual el interpreta que es como si fuera una foránea y nos sirve para llenar la información relacionada al momento de hacer un query.

    Edinson Jesús Paternina Rivera

    Edinson Jesús Paternina Rivera

    student•
    hace 3 años

    Porque en la definición de Categoria no creo la propiedad de "Tareas", la propiedad virtual que esta definida en el Modelo?

      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      La propiedad virtual permite poder sobrescribirla y llenar la información que se necesite al momento de cargar la info desde SQL

    Pablo Cesar Lara Londoño

    Pablo Cesar Lara Londoño

    student•
    hace 2 años

    Like si también hiciste mal la ForeignKey 😂

    tarea.HasOne(p => p.Categoria).WithMany(p => p.Tareas).HasForeignKey(p=> p.CategoriaId);

    Juan Betancur

    Juan Betancur

    student•
    hace 3 años

    cómo se haría una relación de mucho a muchos?

      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      Hola Juan puedes consultar esta documentación para poder lograrlo, es bastante sencillo y simplemente usas el Many para ambas referencias en una tabla intermedia que relacione tus 2 tablas: https://www.learnentityframeworkcore.com/configuration/many-to-many-relationship-configuration

    Rodolfo Maximo Hernández

    Rodolfo Maximo Hernández

    student•
    hace 3 años

    Cuando se tienen más modelos y se necesita realizar las restricciones con Fluent API, ¿es recomendable seguir haciendo dicha configuración en el archivo de contexto? ¿Si no es así, como se debería realizar?

      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      Puedes crear diferentes clases que reciban el contexto de EF como párametro. lo modifiquen y distribuir la lógica cuando va creciendo mucho. Puedes hacerla por nucleos de negocios, UsuariosConfig por ejemplo para todo lo relacionado a usuarios, roles y permisos y asi...

    Francisco Javier Pineda Giraldo

    Francisco Javier Pineda Giraldo

    student•
    hace 3 años

    Miguel y compañeros que significa la p en la expresión lamda p => p.atributo es Una nemotecnia? o por que la p

      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      Básicamente estas creando una función anonima y necesitas colocar un alias al parámetro, yo generalmente uso la 'p' pero depende mucho de la forma de programar

      Sergio Sanchez

      Sergio Sanchez

      student•
      hace 2 años

      yo uso item:

      item => item.attribute
    Juan Fonseca

    Juan Fonseca

    student•
    hace un mes

    Solo quiero comentar que lo que dice en cuanto a nombrar las tablas en singular no es verdad. Las tablas se nombran en plural ya que guardan varios registros (entonces no guardo una "tarea", guardo varias "tareas". Es por eso que en la creación de la BD el Framework creó las tablas en plural

    Junier Ayala Perez

    Junier Ayala Perez

    student•
    hace 2 meses

    modelBuilder.Entity<Tarea>(tarea =>

            {

                tarea.ToTable("Tarea");

                tarea.HasKey(p => p.TareaId);

                tarea.Property(p => p.Titulo).IsRequired().HasMaxLength(200);

                tarea.Property(p => p.Descripcion).IsRequired(false).HasMaxLength(500);

                tarea.Property(p => p.PrioridadTarea).IsRequired();

                tarea.Property(p => p.FechaCreacion).IsRequired();

                // Relación entre Tarea y Categoria

                tarea.HasOne(p => p.Categoria)

                     .WithMany(c => c.Tareas)

                     .HasForeignKey(p => p.CategoriaId);

            });

    Israel Zapata Pacheco

    Israel Zapata Pacheco

    student•
    hace 3 años

    Hola, no entiendo este error, mi relación la quiero de muchos canales a 1 usuario , alguna idea?

    Captura de pantalla 2023-01-30 231603.png

      Miguel Teheran

      Miguel Teheran

      teacher•
      hace 3 años

      HasOne no se usa para Ids sino para las propiedades de referencia, aca esta la info: https://www.learnentityframeworkcore.com/configuration/fluent-api/hasone-method

      Israel Zapata Pacheco

      Israel Zapata Pacheco

      student•
      hace 3 años

      Muchas gracias!!

    Luis Collymoore

    Luis Collymoore

    student•
    hace 5 meses

       modelBuilder.Entity<Tarea>(tarea =>    {        tarea.ToTable("Tarea");        tarea.HasKey(c => c.TareaId);        tarea.HasOne(c => c.Categoria).WithMany(c => c.Tareas).HasForeignKey(c => c.CategoriaId);        tarea.Property(c => c.Titulo).HasMaxLength(200).IsRequired();        tarea.Property(c => c.Descripcion);        tarea.Property(c => c.PrioridadTarea);        tarea.Property(c => c.FechaCreacion);    });    }   

Escuelas

  • Desarrollo Web
    • Fundamentos del Desarrollo Web Profesional
    • Diseño y Desarrollo Frontend
    • Desarrollo Frontend con JavaScript
    • Desarrollo Frontend con Vue.js
    • Desarrollo Frontend con Angular
    • Desarrollo Frontend con React.js
    • Desarrollo Backend con Node.js
    • Desarrollo Backend con Python
    • Desarrollo Backend con Java
    • Desarrollo Backend con PHP
    • Desarrollo Backend con Ruby
    • Bases de Datos para Web
    • Seguridad Web & API
    • Testing Automatizado y QA para Web
    • Arquitecturas Web Modernas y Escalabilidad
    • DevOps y Cloud para Desarrolladores Web
  • English Academy
    • Inglés Básico A1
    • Inglés Básico A2
    • Inglés Intermedio B1
    • Inglés Intermedio Alto B2
    • Inglés Avanzado C1
    • Inglés para Propósitos Específicos
    • Inglés de Negocios
  • Marketing Digital
    • Fundamentos de Marketing Digital
    • Marketing de Contenidos y Redacción Persuasiva
    • SEO y Posicionamiento Web
    • Social Media Marketing y Community Management
    • Publicidad Digital y Paid Media
    • Analítica Digital y Optimización (CRO)
    • Estrategia de Marketing y Growth
    • Marketing de Marca y Comunicación Estratégica
    • Marketing para E-commerce
    • Marketing B2B
    • Inteligencia Artificial Aplicada al Marketing
    • Automatización del Marketing
    • Marca Personal y Marketing Freelance
    • Ventas y Experiencia del Cliente
    • Creación de Contenido para Redes Sociales
  • Inteligencia Artificial y Data Science
    • Fundamentos de Data Science y AI
    • Análisis y Visualización de Datos
    • Machine Learning y Deep Learning
    • Data Engineer
    • Inteligencia Artificial para la Productividad
    • Desarrollo de Aplicaciones con IA
    • AI Software Engineer
  • Ciberseguridad
    • Fundamentos de Ciberseguridad
    • Hacking Ético y Pentesting (Red Team)
    • Análisis de Malware e Ingeniería Forense
    • Seguridad Defensiva y Cumplimiento (Blue Team)
    • Ciberseguridad Estratégica
  • Liderazgo y Habilidades Blandas
    • Fundamentos de Habilidades Profesionales
    • Liderazgo y Gestión de Equipos
    • Comunicación Avanzada y Oratoria
    • Negociación y Resolución de Conflictos
    • Inteligencia Emocional y Autogestión
    • Productividad y Herramientas Digitales
    • Gestión de Proyectos y Metodologías Ágiles
    • Desarrollo de Carrera y Marca Personal
    • Diversidad, Inclusión y Entorno Laboral Saludable
    • Filosofía y Estrategia para Líderes
  • Diseño de Producto y UX
    • Fundamentos de Diseño UX/UI
    • Investigación de Usuarios (UX Research)
    • Arquitectura de Información y Usabilidad
    • Diseño de Interfaces y Prototipado (UI Design)
    • Sistemas de Diseño y DesignOps
    • Redacción UX (UX Writing)
    • Creatividad e Innovación en Diseño
    • Diseño Accesible e Inclusivo
    • Diseño Asistido por Inteligencia Artificial
    • Gestión de Producto y Liderazgo en Diseño
    • Diseño de Interacciones Emergentes (VUI/VR)
    • Desarrollo Web para Diseñadores
    • Diseño y Prototipado No-Code
  • Contenido Audiovisual
    • Fundamentos de Producción Audiovisual
    • Producción de Video para Plataformas Digitales
    • Producción de Audio y Podcast
    • Fotografía y Diseño Gráfico para Contenido Digital
    • Motion Graphics y Animación
    • Contenido Interactivo y Realidad Aumentada
    • Estrategia, Marketing y Monetización de Contenidos
  • Desarrollo Móvil
    • Fundamentos de Desarrollo Móvil
    • Desarrollo Nativo Android con Kotlin
    • Desarrollo Nativo iOS con Swift
    • Desarrollo Multiplataforma con React Native
    • Desarrollo Multiplataforma con Flutter
    • Arquitectura y Patrones de Diseño Móvil
    • Integración de APIs y Persistencia Móvil
    • Testing y Despliegue en Móvil
    • Diseño UX/UI para Móviles
  • Diseño Gráfico y Arte Digital
    • Fundamentos del Diseño Gráfico y Digital
    • Diseño de Identidad Visual y Branding
    • Ilustración Digital y Arte Conceptual
    • Diseño Editorial y de Empaques
    • Motion Graphics y Animación 3D
    • Diseño Gráfico Asistido por Inteligencia Artificial
    • Creatividad e Innovación en Diseño
  • Programación
    • Fundamentos de Programación e Ingeniería de Software
    • Herramientas de IA para el trabajo
    • Matemáticas para Programación
    • Programación con Python
    • Programación con JavaScript
    • Programación con TypeScript
    • Programación Orientada a Objetos con Java
    • Desarrollo con C# y .NET
    • Programación con PHP
    • Programación con Go y Rust
    • Programación Móvil con Swift y Kotlin
    • Programación con C y C++
    • Administración Básica de Servidores Linux
  • Negocios
    • Fundamentos de Negocios y Emprendimiento
    • Estrategia y Crecimiento Empresarial
    • Finanzas Personales y Corporativas
    • Inversión en Mercados Financieros
    • Ventas, CRM y Experiencia del Cliente
    • Operaciones, Logística y E-commerce
    • Gestión de Proyectos y Metodologías Ágiles
    • Aspectos Legales y Cumplimiento
    • Habilidades Directivas y Crecimiento Profesional
    • Diversidad e Inclusión en el Entorno Laboral
    • Herramientas Digitales y Automatización para Negocios
  • Blockchain y Web3
    • Fundamentos de Blockchain y Web3
    • Desarrollo de Smart Contracts y dApps
    • Finanzas Descentralizadas (DeFi)
    • NFTs y Economía de Creadores
    • Seguridad Blockchain
    • Ecosistemas Blockchain Alternativos (No-EVM)
    • Producto, Marketing y Legal en Web3
  • Recursos Humanos
    • Fundamentos y Cultura Organizacional en RRHH
    • Atracción y Selección de Talento
    • Cultura y Employee Experience
    • Gestión y Desarrollo de Talento
    • Desarrollo y Evaluación de Liderazgo
    • Diversidad, Equidad e Inclusión
    • AI y Automatización en Recursos Humanos
    • Tecnología y Automatización en RRHH
  • Finanzas e Inversiones
    • Fundamentos de Finanzas Personales y Corporativas
    • Análisis y Valoración Financiera
    • Inversión y Mercados de Capitales
    • Finanzas Descentralizadas (DeFi) y Criptoactivos
    • Finanzas y Estrategia para Startups
    • Inteligencia Artificial Aplicada a Finanzas
    • Domina Excel
    • Financial Analyst
    • Conseguir trabajo en Finanzas e Inversiones
  • Startups
    • Fundamentos y Validación de Ideas
    • Estrategia de Negocio y Product-Market Fit
    • Desarrollo de Producto y Operaciones Lean
    • Finanzas, Legal y Fundraising
    • Marketing, Ventas y Growth para Startups
    • Cultura, Talento y Liderazgo
    • Finanzas y Operaciones en Ecommerce
    • Startups Web3 y Blockchain
    • Startups con Impacto Social
    • Expansión y Ecosistema Startup
  • Cloud Computing y DevOps
    • Fundamentos de Cloud y DevOps
    • Administración de Servidores Linux
    • Contenerización y Orquestación
    • Infraestructura como Código (IaC) y CI/CD
    • Amazon Web Services
    • Microsoft Azure
    • Serverless y Observabilidad
    • Certificaciones Cloud (Preparación)
    • Plataforma Cloud GCP

Platzi y comunidad

  • Platzi Business
  • Live Classes
  • Lanzamientos
  • Executive Program
  • Trabaja con nosotros
  • Podcast

Recursos

  • Manual de Marca

Soporte

  • Preguntas Frecuentes
  • Contáctanos

Legal

  • Términos y Condiciones
  • Privacidad
  • Tyc promociones
Reconocimientos
Reconocimientos
Logo reconocimientoTop 40 Mejores EdTech del mundo · 2024
Logo reconocimientoPrimera Startup Latina admitida en YC · 2014
Logo reconocimientoPrimera Startup EdTech · 2018
Logo reconocimientoCEO Ganador Medalla por la Educación T4 & HP · 2024
Logo reconocimientoCEO Mejor Emprendedor del año · 2024
De LATAM conpara el mundo
YoutubeInstagramLinkedInTikTokFacebookX (Twitter)Threads