Portabilidad de un modelo basado en código de EF6 a EF Core
Si ha leído todas las advertencias y está a punto para realizar la portabilidad, estas son algunas instrucciones que le ayudarán a empezar.
Instalación de los paquetes NuGet de EF Core
Para usar EF Core, instale el paquete NuGet correspondiente al proveedor de base de datos que quiera usar. Por ejemplo, cuando el destino es SQL Server, tendría que instalar Microsoft.EntityFrameworkCore.SqlServer
. Para obtener más información, vea Proveedores de bases de datos.
Si tiene previsto usar migraciones, también debe instalar el paquete Microsoft.EntityFrameworkCore.Tools
.
No hay problema por dejar el paquete NuGet de EF6 (EntityFramework) instalado, ya que EF Core y EF6 se pueden usar en paralelo en la misma aplicación. Sin embargo, si no va a usar EF6 en ninguna de las áreas de la aplicación, la desinstalación del paquete le ayudará a dar errores de compilación en fragmentos de código que requieren atención.
Intercambio de espacios de nombres
La mayoría de las API que se usan en EF6 se encuentran en el espacio de nombres System.Data.Entity
(y los subespacios de nombres relacionados). El primer cambio de código consiste en cambiar al espacio de nombres Microsoft.EntityFrameworkCore
. Normalmente, empezará con el archivo de código de contexto derivado y, después, avanzará desde allí y solucionará los errores de compilación a medida que aparezcan.
Configuración del contexto (conexión, etc.)
Como se describe en la sección de configuración de una conexión de base de datos, EF Core tiene menos secretos en cuanto a la detección de la base de datos a la que conectarse. Tendrá que reemplazar el método OnConfiguring
en el contexto derivado y usar la API específica del proveedor de base de datos para configurar la conexión a la base de datos.
La mayoría de las aplicaciones EF6 almacenan la cadena de conexión en el archivo App/Web.config
de las aplicaciones. En EF Core, esta cadena de conexión se lee mediante la API ConfigurationManager
. Es posible que tenga que agregar una referencia al ensamblado de System.Configuration
marco para poder usar esta API:
public class BloggingContext : DbContext
{
public DbSet<Blog> Blogs { get; set; }
public DbSet<Post> Posts { get; set; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
optionsBuilder.UseSqlServer(ConfigurationManager.ConnectionStrings["BloggingDatabase"].ConnectionString);
}
}
Advertencia Nunca almacene contraseñas u otros datos confidenciales en el código fuente o los archivos de configuración. Los secretos de producción no se deben usar para desarrollo o prueba. Los secretos no se deben implementar con la aplicación. Se debe acceder a los secretos de producción a través de un medio controlado, como Azure Key Vault. Los secretos de prueba y producción de Azure se pueden almacenar y proteger con el proveedor de configuración de Azure Key Vault.
Actualización del código
En este punto, es cuestión de solucionar los errores de compilación y de revisar el código para ver si los cambios de comportamiento le afectarán.
Migraciones existentes
Realmente no existe una manera viable de realizar la portabilidad de las migraciones de EF6 existentes a EF Core.
Si es posible, es mejor suponer que todas las migraciones anteriores de EF6 se han aplicado a la base de datos y, después, iniciar la migración del esquema desde ese punto mediante EF Core. Para ello, use el comando Add-Migration
para agregar una migración una vez que el modelo se haya trasladado a EF Core. Después, podría quitar todo el código de los métodos Up
y Down
de la migración con scaffolding. Las migraciones posteriores se compararán con el modelo cuando se haya aplicado scaffolding a la migración inicial.
Prueba del puerto
El hecho de que la aplicación se compile no significa que se haya trasladado correctamente a EF Core. Tendrá que probar todas las áreas de la aplicación para asegurarse de que ninguno de los cambios de comportamiento afecte de forma negativa a la aplicación.
Por último, revise los casos detallados que tener en cuenta al hacer la portabilidad para obtener más consejos sobre casos y situaciones específicos en su código.