You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
abp/docs/zh-Hans/Entity-Framework-Core-Oracl...

3.6 KiB

切换到EF Core Oracle提供程序

本文介绍如何将预配置为SqlServer提供程序的 应用程序启动模板 切换到 Oracle 数据库提供程序

本文档使用Devart公司的付费库,因为它是oracle唯一支持EF Core 3.x的库

替换Volo.Abp.EntityFrameworkCore.SqlServer包

解决方案中的 .EntityFrameworkCore 项目依赖于 Volo.Abp.EntityFrameworkCore.SqlServer NuGet包. 删除这个包并且添加相同版本的 Volo.Abp.EntityFrameworkCore.Oracle.Devart 包.

替换模块依赖项

.EntityFrameworkCore 项目中找到 YourProjectName*EntityFrameworkCoreModule 类, 删除 DependsOn attribute 上的typeof(AbpEntityFrameworkCoreSqlServerModule), 添加 typeof(AbpEntityFrameworkCoreOracleDevartModule) (或者替换 using Volo.Abp.EntityFrameworkCore.SqlServer;using Volo.Abp.EntityFrameworkCore.Oracle.Devart;).

UseOracle()

Find UseSqlServer() calls in your solution, replace with UseOracle(). Check the following files:

  • YourProjectNameEntityFrameworkCoreModule.cs inside the .EntityFrameworkCore project.
  • YourProjectNameMigrationsDbContextFactory.cs inside the .EntityFrameworkCore.DbMigrations project.

In the CreateDbContext() method of the YourProjectNameMigrationsDbContextFactory.cs, replace the following code block

查找你的解决方案中 UseSqlServer()调用,替换为 UseOracle(). 检查下列文件:

  • .EntityFrameworkCore 项目中的YourProjectNameEntityFrameworkCoreModule.cs.
  • .EntityFrameworkCore 项目中的YourProjectNameMigrationsDbContextFactory.cs.

使用以下代码替换YourProjectNameMigrationsDbContextFactory.cs中的 CreateDbContext() 方法:

var builder = new DbContextOptionsBuilder<YourProjectNameMigrationsDbContext>()
                .UseSqlServer(configuration.GetConnectionString("Default"));

与这个

var builder = (DbContextOptionsBuilder<YourProjectNameMigrationsDbContext>)
	new DbContextOptionsBuilder<YourProjectNameMigrationsDbContext>().UseOracle
	(
		configuration.GetConnectionString("Default")
	);

根据你的解决方案的结构,你可能发现更多需要改变代码的文件.

更改连接字符串

Oracle连接字符串与SQL Server连接字符串不同. 所以检查你的解决方案中所有的 appsettings.json 文件,更改其中的连接字符串. 有关oracle连接字符串选项的详细内容请参见connectionstrings.com.

通常需要更改 .DbMigrator.Web 项目里面的 appsettings.json ,但它取决于你的解决方案结构.

重新生成迁移

启动模板使用Entity Framework Core的Code First迁移. EF Core迁移取决于所选的DBMS提供程序. 因此更改DBMS提供程序会导致迁移失败.

  • 删除 .EntityFrameworkCore.DbMigrations 项目下的Migrations文件夹,并重新生成解决方案.
  • 在包管理控制台中运行 Add-Migration "Initial"(在解决方案资源管理器选择 .DbMigrator (或 .Web) 做为启动项目并且选择 .EntityFrameworkCore.DbMigrations 做为默认项目).

这将创建一个配置所有数据库对象(表)的数据库迁移.

运行 .DbMigrator 项目创建数据库和初始种子数据.

运行应用程序

它已准备就绪, 只需要运行该应用程序与享受编码.