当前位置:Gxlcms > 数据库问题 > ABP .net core集成访问Oracle数据库

ABP .net core集成访问Oracle数据库

时间:2021-07-01 10:21:17 帮助过:57人阅读

1.添加包引用:

Microsoft.EntityFrameworkCore.Relational
Oracle.EntityFrameworkCore
2.重写DbContext OnModelCreating

/// <summary>
        /// 判断如果是Oracle,需要执行Schema
        /// </summary>
        /// <param name="modelBuilder"></param>

        protected override void OnModelCreating(ModelBuilder modelBuilder)
        {
            //判断当前数据库是Oracle 需要手动添加Schema(DBA提供的数据库账号名称)
            if (this.Database.IsOracle())
            {
                modelBuilder.HasDefaultSchema(new SqlConnectionStringBuilder(Database.GetDbConnection().ConnectionString).UserID.ToUpper());
            }
            base.OnModelCreating(modelBuilder);
        }

3.在DbContextConfigurer 中启用oracle连接

 public static class EzxDbContextConfigurer
    {
        public static void Configure(DbContextOptionsBuilder<EzxDbContext> builder, string connectionString)
        {
            //builder.UseSqlServer(connectionString);
            builder.UseOracle(connectionString);
        }

        public static void Configure(DbContextOptionsBuilder<EzxDbContext> builder, DbConnection connection)
        {
            builder.UseSqlServer(connection);
        }
    }

4.在appsettings.json中添加Oracle的字符串的配置

{
  "ConnectionStrings": {
    //"Default": "Server=localhost; Database=EzxDb; Trusted_Connection=True;"
    "Default": "User Id=cis;Password=cis;Data Source=127.0.0.1:1521/hisbd"
  },
  "Authentication": {
    "JwtBearer": {
      "IsEnabled": "true",
      "SecurityKey": "Ezx_C421AAEE0D114E9C",
      "Issuer": "Ezx",
      "Audience": "Ezx"
    }
  },
  "Logging": {
    "IncludeScopes": false,
    "LogLevel": {
      "Default": "Debug",
      "System": "Information",
      "Microsoft": "Information"
    }
  }
}

  

ABP .net core集成访问Oracle数据库

标签:this   orm   nal   tab   连接   判断   connect   rri   summary   

人气教程排行