mysql 不能用dbcontext_一个请求需要调用两个不同的数据库 添加DbContext

当请求进入application中的方法时 会开启一个工作单元    这里面调用不同的DbContext 会默认使用第一次调用的DbContext

需要手动开启工作单元来隔离两个不同的DbContext进行操作

599b425de8f0a56544aef83ddfa76193.png

ABP中出现这个问题 看看方法是不是异步的  返回类型是不是Task

1.比如自己封装了一个开启工作单元的方法

public async Task NewUnitOfWork(FuncFunc)

{using (var unitOfWork =unitOfWorkManager.Begin(TransactionScopeOption.RequiresNew))

{try{awaitFunc.Invoke();awaitunitOfWork.CompleteAsync();

}catch(DbUpdateException)

{throw new UserFriendlyException("当前记录已经被使用");

}catch(Exception ex)

{throw newUserFriendlyException(ex.Message);

}

}

}

2.这个委托里面会写对数据库的查询操作  都是异步的  调用这个委托的时候 也是通过 await调用的 委托的返回值类型就要写Task  不然就会报上面的错误

await delUnitOfWork.NewUnitOfWork(async () =>{

distributorGroupModel= awaitcustomerGroupGroupRepository.GetAll()

.Where(t=> t.Name == "经销商")

.Where(t=> t.IsSystem == true)

.FirstOrDefaultAsync();if (distributorGroupModel == null)

{throw new UserFriendlyException("初始化数据不存在");

}

customer= awaitcustomerRepository.GetAsync(input.Id.Value);

});

添加DbContext   配置连接字符串方式

1.在Web项目的Startup入口配置Dbcontext连接字符串

d4698ab254d12cf13117d94ce214c65e.png

bacb449aaa5d179c6b7ea7aefefde7aa.png

这三种写法一样 都是获取配置文件中的连接字符串

2.非Web项目 不存在Startup入口 可以在EF的Moduel中配置连接字符串  这个参数可以 直接写连接字符串

1314ab768c16c55e559f9472105d9cb2.png

如果这种方式报错  就改成下面这样

4336b097c04c878c7ac4a3ea6da8566d.png

3.在MyDbContext中重写OnConfiguring进行配置连接字符串

可以通过注入IConfigurationRoot对象来获取appsetting.json配置文件

private readonlyIConfigurationRoot _appConfiguration;publicStartup(IHostingEnvironment env)

{

_appConfiguration=env.GetAppConfiguration();

}

这个GetAppConfiguration是扩展方法  写在 Web.Core层  所以Application层,Core层,EF层不能引用Web.Core层  所以不能调用这个扩展方法  通过这种方式调用  其实上面那个扩展方法里面就是调用了下面这个方法

private readonlyIConfigurationRoot _appConfiguration;publicIMSEntityFrameworkModule(IHostingEnvironment env)

{

_appConfiguration=AppConfigurations.Get(env.ContentRootPath, env.EnvironmentName, env.IsDevelopment());

}

protected override voidOnConfiguring(DbContextOptionsBuilder optionsBuilder)

{//从 appsetting.json 中获取配置信息

var config = newConfigurationBuilder()

.SetBasePath(Directory.GetCurrentDirectory())

.AddJsonFile("appsettings.json")

.Build();

optionsBuilder.UseSqlServer(config.GetConnectionString("DefaultConnection"));

}

protected override voidOnConfiguring(DbContextOptionsBuilder optionsBuilder)

{base.OnConfiguring(optionsBuilder);

configuration= ConfigManager.LoadConfig("appsettings.json");

optionsBuilder.UseSqlServer(configuration["ConnectionStrings"]);

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值