Translate

Mostrando las entradas con la etiqueta Entity Framework Core. Mostrar todas las entradas
Mostrando las entradas con la etiqueta Entity Framework Core. Mostrar todas las entradas

sábado, 19 de junio de 2021

Paquetes EF Core NuGet

 

Entity Framework Core (EF Core) se instala con paquetes NuGet.  El proceso habitual para instalar paquetes es:

  • Decidir sobre un proveedor de base de datos e instalar el paquete apropiado 
  • Instalar Microsoft.EntityFrameworkCore y Microsoft.EntityFrameworkCore.Relational si utiliza una base de datos relacional. Esto ayuda a garantizar que se utilicen versiones coherentes y también significa que NuGet le informará cuando se envíen nuevas versiones de paquetes.
  • Opcionalmente, decidir qué tipo de herramientas necesita e instale los paquetes apropiados para eso.

Asegúrese de instalar la misma versión de todos los paquetes EF Core enviados por Microsoft. Por ejemplo, si está instalada la versión 5.0.3 de Microsoft.EntityFrameworkCore.SqlServer, todos los demás paquetes Microsoft.EntityFrameworkCore. * También deben estar en 5.0.3.

También asegúrese de que los paquetes externos sean compatibles con la versión de EF Core que se esté utilizando. En particular, verifique que el proveedor de la base de datos externa sea compatible con la versión de EF Core que está utilizando. Las nuevas versiones principales de EF Core generalmente requieren un proveedor de base de datos actualizado.

lunes, 14 de junio de 2021

Introducción a Entity Framework Core 5 parte 3


Seguimos EF.

Cada solución de EF Core tendrá al menos una implementación de DbContext. ¿Qué es DbContext? DbContext es una clase base especializada que rastrea nuestras operaciones en memoria, lo que nos permite escribir y ejecutar consultas, rastrear cambios que podemos persistir en nuestra base de datos e interactuar con nuestro motor de base de datos de manera indirecta o directa en circunstancias excepcionales.

Para comenzar a usar EF Core 5, necesitamos definir una clase que se derive de DbContext y contenga nuestros modelos. Normalmente, nuestras clases se asignarán una a una con las tablas de nuestra base de datos, y las relaciones entre las tablas se definen mediante convenciones de navegación. Veremos cómo funciona esto a medida que vayamos definiendo nuestras clases.

Para esta teoría vamos a hacer un modelado simple, con Entity Framework nuestras clases no son obligadas a extender de una clase del framework o tener algo especial. 

En nuestro ejemplo vamos a definir clases que modelen la lógica de un blog. 

using System.Collections.Generic;

using Microsoft.EntityFrameworkCore;


namespace EFGetStarted

{

    public class BloggingContext : DbContext  {

        public DbSet<Blog> Blogs { get; set; }

        public DbSet<Post> Posts { get; set; }


        // The following configures EF to create a Sqlite database file as `C:\blogging.db`.

        // For Mac or Linux, change this to `/tmp/blogging.db` or any other absolute path.

        protected override void OnConfiguring(DbContextOptionsBuilder options)

            => options.UseSqlite(@"Data Source=C:\blogging.db");

    }


    public class Blog

    {

        public int BlogId { get; set; }

        public string Url { get; set; }


        public List<Post> Posts { get; } = new List<Post>();

    }


    public class Post

    {

        public int PostId { get; set; }

        public string Title { get; set; }

        public string Content { get; set; }


        public int BlogId { get; set; }

        public Blog Blog { get; set; }

    }

}

Los siguientes pasos utilizan migraciones para crear una base de datos.

> dotnet ef migrations add InitialCreate

> dotnet ef database update

El comando de migraciones crea una migración para crear el conjunto inicial de tablas para el modelo. El comando de actualización de la base de datos crea la base de datos y le aplica la nueva migración. 

Veamos un ejemplo de creación, lectura, update y delete: 


using System;

using System.Linq;


namespace EFGetStarted

{

    internal class Program

    {

        private static void Main()

        {

            using (var db = new BloggingContext())

            {

                // Note: This sample requires the database to be created before running.


                // Create

                Console.WriteLine("Inserting a new blog");

                db.Add(new Blog { Url = "http://blogs.msdn.com/adonet" });

                db.SaveChanges();


                // Read

                Console.WriteLine("Querying for a blog");

                var blog = db.Blogs

                    .OrderBy(b => b.BlogId)

                    .First();


                // Update

                Console.WriteLine("Updating the blog and adding a post");

                blog.Url = "https://devblogs.microsoft.com/dotnet";

                blog.Posts.Add(

                    new Post { Title = "Hello World", Content = "I wrote an app using EF Core!" });

                db.SaveChanges();


                // Delete

                Console.WriteLine("Delete the blog");

                db.Remove(blog);

                db.SaveChanges();

            }

        }

    }

}


Dejo link: https://docs.microsoft.com/en-us/ef/core/get-started/overview/first-app?tabs=netcore-cli

Introducción a Entity Framework Core 5 parte 2


Seguimos con EF. 

Para comenzar, debemos instalar la última versión de .NET 5 SDK. Técnicamente, EF Core 5 puede ejecutarse en .NET Core 3.1, pero vamos a utilizar .NET 5.

Comenzando con una nueva aplicación de consola, necesitaremos instalar los siguientes paquetes, asegurándonos de que todas las versiones sean 5.0.0:

  • Microsoft.EntityFrameworkCore
  • Microsoft.EntityFrameworkCore.Design
  • Microsoft.EntityFrameworkCore.Sqlite
Primero vamos a hacer un proyecto de consola: 

> dotnet new console

Para instalar dotnet-ef debemos hacer : 

> dotnet new tool-manifest

> dotnet tool install dotnet-ef

> dotnet add package Microsoft.EntityFrameworkCore --version 5.0.6

>dotnet add package Microsoft.EntityFrameworkCore.Design --version 5.0.6

>dotnet add package Microsoft.EntityFrameworkCore.Sqlite --version 5.0.6

En este caso estamos utilizando Sqlite, pero podemos utilizar: 

Cuando terminemos de configurar nuestro proyecto, podemos ejecutar el comando dotnet-ef, donde el unicornio EF nos saludará.

> dotnet ef

Dejo link: https://docs.microsoft.com/en-us/ef/core/get-started/overview/first-app?tabs=netcore-cli


lunes, 7 de junio de 2021

Introducción a Entity Framework Core 5


Entity Framework es un mapeador relacional de objetos (ORM), que ayuda a los desarrolladores a superar los desajustes de impedancia entre C # y el esquema de una instancia de base de datos.

Entity Framework ha recorrido un largo camino desde su inicio original. Concebida inicialmente como una herramienta centrada en el diseñador que depende en gran medida de la interfaz gráfica de usuario de Visual Studio y SQL Server, la filosofía actual de EF reconoce la necesidad de ser más amigable con ideas como control de fuente distribuido, servidores de compilación, múltiples motores de base de datos y sistemas operativos.

Entity Framework (EF) Core es una versión ligera, extensible, de código abierto y multiplataforma de la popular tecnología de acceso a datos de Entity Framework.

EF Core puede servir como un mapeador relacional de objetos (ORM), que:

  • Permite a los desarrolladores de .NET trabajar con una base de datos utilizando objetos .NET.
  • Elimina la necesidad de la mayor parte del código de acceso a datos que normalmente es necesario escribir.
  • EF Core admite muchos motores de base de datos; consulte Proveedores de bases de datos para obtener más detalles.

Con EF Core, el acceso a los datos se realiza mediante un modelo. Un modelo se compone de clases de entidad y un objeto de contexto que representa una sesión con la base de datos. El objeto de contexto permite consultar y guardar datos. 

EF admite los siguientes enfoques de desarrollo de modelos:
  • Genere un modelo a partir de una base de datos existente.
  • Codifique manualmente un modelo para que coincida con la base de datos.
  • Una vez que se crea un modelo, use EF Migrations para crear una base de datos a partir del modelo. Las migraciones permiten evolucionar la base de datos a medida que cambia el modelo.

Si bien EF Core es bueno para abstraer muchos detalles de programación, existen algunas mejores prácticas aplicables a cualquier ORM que ayudan a evitar errores comunes en las aplicaciones de producción:

  • El conocimiento de nivel intermedio o superior del servidor de base de datos subyacente es esencial para diseñar, depurar, perfilar y migrar datos en aplicaciones de producción de alto rendimiento. Por ejemplo, conocimiento de claves primarias y externas, restricciones, índices, normalización, declaraciones DML y DDL, tipos de datos, creación de perfiles, etc.
  • Pruebas funcionales y de integración: es importante replicar el entorno de producción lo más fielmente posible para:
    • Encontrar problemas en la aplicación que solo aparecen cuando se usa una versión o edición específica del servidor de base de datos.
    • Detectar los cambios importantes al actualizar EF Core y otras dependencias. Por ejemplo, agregar o actualizar marcos como ASP.NET Core, OData o AutoMapper. Estas dependencias pueden afectar EF Core de formas inesperadas.
    • Prueba de rendimiento y estrés con cargas representativas. El uso ingenuo de algunas funciones no se adapta bien. Por ejemplo, múltiples colecciones Incluye, uso intensivo de carga diferida, consultas condicionales en columnas no indexadas, actualizaciones masivas e inserciones con valores generados por la tienda, falta de manejo de simultaneidad, modelos grandes, política de caché inadecuada.
    • Revisión de seguridad: por ejemplo, manejo de cadenas de conexión y otros secretos, permisos de base de datos para operaciones sin implementación, validación de entrada para SQL sin procesar, cifrado para datos confidenciales.
    • Asegurarse de que el registro y los diagnósticos sean suficientes y utilizables. Por ejemplo, la configuración de registro adecuada, las etiquetas de consulta y Application Insights.
    • Encontrar error de recuperación. Prepare contingencias para escenarios de fallas comunes, como reversión de versiones, servidores de reserva, escalado horizontal y equilibrio de carga, mitigación de DoS y copias de seguridad de datos.
    • Despliegue y migración de aplicaciones. Planifique cómo se aplicarán las migraciones durante la implementación; hacerlo al inicio de la aplicación puede sufrir problemas de concurrencia y requiere permisos más altos de los necesarios para el funcionamiento normal. Utilice la preparación para facilitar la recuperación de errores fatales durante la migración. Para obtener más información, consulte Aplicación de migraciones.
    • Tests detalladas de las migraciones generadas. Las migraciones deben probarse a fondo antes de aplicarse a los datos de producción. La forma del esquema y los tipos de columna no se pueden cambiar fácilmente una vez que las tablas contienen datos de producción. Por ejemplo, en SQL Server, nvarchar (max) y decimal (18, 2) rara vez son los mejores tipos para columnas asignadas a propiedades de cadena y decimal, pero esos son los valores predeterminados que utiliza EF porque no tiene conocimiento de su guión.

Dejo link: https://docs.microsoft.com/en-us/ef/core/

domingo, 10 de septiembre de 2017

Top 5 de nuevas características de Entity Framework Core 1.0


.net core viene tomando cada vez más relevancia en el mundo del desarrollo y como era de pensar cada vez se nutre más de sus frameworks por esta razón vamos a analizar 5 características de Entity Framework Core 1.0

Entity Framework Core es un mapeador relacional de objetos (ORM) que permite a los desarrolladores de .NET trabajar con una base de datos utilizando objetos .NET. Elimina la necesidad de la mayor parte del código de acceso a datos que los desarrolladores normalmente necesitan escribir. Hablando mal y pronto un hibernate de .net y microsoft

1. Cross plataforma, de igual manera que .net core su mayor fortaleza es que corre en cualquier plataforma como Windows, Mac, y mi amado Linux. A la vez permite conectarse a diferentes bases de datos como SQL Server, SQLite, Postgres, MySQL y pronto va estar desarrollo la conexión a bases nosql

2.Liviano, modular y extensible: Entity Framework Core se ha descompuesto en paquetes / componentes manejables más pequeños, por lo tanto podemos utilizar los que sean útiles para el proyecto. Estos componentes también se pueden ampliar para agregar funcionalidad adicional.

3.In-Memory Provider:  Se puede utilizar un almacén de datos en memoria, puede ejercitar su código de acceso de datos contra una base de datos real que sólo existe en la memoria. Facilitando las pruebas.

4.Propiedades ocultas o Shadow: Podemos modificar campos que solo existen en la base que se denominan shadow:

public class CoursesContext : DbContext
{
    public DbSet<Course> Courses { get; set; }
    public DbSet<Student> Students { get; set; }

    protected override void OnModelCreating(ModelBuilder modelBuilder)
    {
        modelBuilder.Entity<Course>()
            .Property<DateTimeOffset>("LastUpdated");
    }
}

context.Entry(myCourse).Property("LastUpdated").CurrentValue = DateTimeOffset.Now;

5.Evaluación mixta cliente/servidor: La evaluación mixta cliente/servidor permite que las consultas contengan una lógica que se pueda evaluar en el cliente.

Por ejemplo tenemos un método así:

public static string AddTitle(string strFirstName)
{
    if (!strFirstName.ToLower().StartsWith("Mr"))
    {
        strFirstName = string.Concat("Mr.", strFirstName);
    }
    return strFirstName;
}

Podemos hacer la siguiente consulta:

var emp = context.Employee
    .Where(emp => emp.Gender == "M")
    .Select(employee => new
    {
        FirstName = AddTitle(employee.FirstName),
        LastName  = employee.LastName
    })
    .ToList();

Donde llamamos a la función AddTitle que se ejecutará en memoria.

Que piensan? es acertado este Top 5?

Dejo link: http://www.csharpstar.com/new-features-of-entity-framework-core/