一个请求需要调用两个不同的数据库 添加DbContext
当请求进入application中的方法时 会开启一个工作单元 这里面调用不同的DbContext 会默认使用第一次调用的DbContext
需要手动开启工作单元来隔离两个不同的DbContext进行操作
ABP中出现这个问题 看看方法是不是异步的 返回类型是不是Task
1.比如自己封装了一个开启工作单元的方法
public async Task NewUnitOfWork(Func<Task> Func)
{
using (var unitOfWork = unitOfWorkManager.Begin(TransactionScopeOption.RequiresNew))
{
try
{
await Func.Invoke();
await unitOfWork.CompleteAsync();
}
catch (DbUpdateException)
{ throw new UserFriendlyException("当前记录已经被使用");
}
catch (Exception ex)
{
throw new UserFriendlyException(ex.Message);
}
}
}
2.这个委托里面会写对数据库的查询操作 都是异步的 调用这个委托的时候 也是通过 await调用的 委托的返回值类型就要写Task 不然就会报上面的错误
await delUnitOfWork.NewUnitOfWork(async () =>
{
distributorGroupModel = await customerGroupGroupRepository.GetAll()
.Where(t => t.Name == "经销商")
.Where(t => t.IsSystem == true)
.FirstOrDefaultAsync();
if (distributorGroupModel == null)
{
throw new UserFriendlyException("初始化数据不存在");
}
customer = await customerRepository.GetAsync(input.Id.Value);
});
添加DbContext 配置连接字符串方式
1.在Web项目的Startup入口配置Dbcontext连接字符串
这三种写法一样 都是获取配置文件中的连接字符串
2.非Web项目 不存在Startup入口 可以在EF的Moduel中配置连接字符串 这个参数可以 直接写连接字符串
如果这种方式报错 就改成下面这样
3.在MyDbContext中重写OnConfiguring进行配置连接字符串
可以通过注入IConfigurationRoot对象来获取appsetting.json配置文件
private readonly IConfigurationRoot _appConfiguration; public Startup(IHostingEnvironment env)
{
_appConfiguration = env.GetAppConfiguration();
}
这个GetAppConfiguration是扩展方法 写在 Web.Core层 所以Application层,Core层,EF层不能引用Web.Core层 所以不能调用这个扩展方法 通过这种方式调用 其实上面那个扩展方法里面就是调用了下面这个方法
private readonly IConfigurationRoot _appConfiguration; public IMSEntityFrameworkModule(IHostingEnvironment env)
{
_appConfiguration = AppConfigurations.Get(env.ContentRootPath, env.EnvironmentName, env.IsDevelopment());
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{ // 从 appsetting.json 中获取配置信息
var config = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json")
.Build(); optionsBuilder.UseSqlServer(config.GetConnectionString("DefaultConnection"));
}
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
base.OnConfiguring(optionsBuilder);
configuration = ConfigManager.LoadConfig("appsettings.json");
optionsBuilder.UseSqlServer(configuration["ConnectionStrings"]);
}
一个请求需要调用两个不同的数据库 添加DbContext的更多相关文章
- SpringCloud的Hystrix(一) 一个消费者内的两个服务监控
一.概念与定义 1.服务雪崩 在微服务架构中,整个系统按业务拆分出一个个服务,这些服务之间可以相互调用(RPC),为了保证服务的高可用,单个服务通常会集群部署. 但是由于网络原因或自身原因,服务并不能 ...
- Jmeter正则表达式提取器--将上一个请求的结果作为下一个请求的参数
正则表达式提取器是一个后置处理器,作用是在请求完成后,从响应数据中截取一部分字符串保存到变量中,以便下一个请求使用 1.首先在线程组下添加两个HTTP请求, 2.添加好两个HTTP请求后,在每个HTT ...
- Spring MVC 处理一个请求的流程分析
Spring MVC是Spring系列框架中使用频率最高的部分.不管是Spring Boot还是传统的Spring项目,只要是Web项目都会使用到Spring MVC部分.因此程序员一定要熟练掌握MV ...
- chrome 浏览器的预提取资源机制导致的一个请求发送两次的问题以及ClientAbortException异常
调查一个 pdf 打印报错: ExceptionConverter: org.apache.catalina.connector.ClientAbortException: java.net.Sock ...
- JavaScript中一个方法同时发送两个ajax请求问题
今天在做项目中遇到一个问题,大概是在一个jsp页面同时有一个select下拉搜索条件框和一个Bootstrap表格展示列表.这两个都要通过ajax向后台拿数据,而且要在页面加载时完成.当时的做法是: ...
- 调用webapi 错误:使用 HTTP 谓词 POST 向虚拟目录发送了一个请求,而默认文档是不支持 GET 或 HEAD 以外的 HTTP 谓词的静态文件。的解决方案
第一次调用webapi出错如下: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http:// ...
- Volley缓存说明——一个请求两次回调
从上一篇文章Android 异步网络请求框架-Volley了解volley的一些出来过程,当然也包含网络请求和缓存处理的流程,但是在此需要单独做一些说明. 我在使用过程中忽略了一个事情,就是一个网络请 ...
- 面试连环炮系列(十):一个线程调用两次start会怎么样
一个线程调用两次start会怎么样 Java的线程是不允许启动两次的,第二次调用必然会抛出IllegalThreadStateException,这是一种运行时异常. 谈谈线程的生命周期和状态转移 新 ...
- 用一个bat文件调用另外两个bat文件,当1.bat执行完后再执行2.bat
用一个bat文件调用另外两个bat文件,当1.bat执行完后再执行2.bat 摘自:https://zhidao.baidu.com/question/492732911.html @echo off ...
随机推荐
- Kattis之旅——Rational Arithmetic
Input The first line of input contains one integer, giving the number of operations to perform. Then ...
- opencv3.1线性可分svm例子及函数分析
https://www.cnblogs.com/qinguoyi/p/7272218.html //摘自:http://docs.opencv.org/2.4/doc/tutorials/ml/int ...
- v-show v-if 的使用
v-show:通过切换元素的display CSS属性实现显示隐藏: v-if:根据表达式的真假实现显示隐藏,如果隐藏,它绑定的元素都会销毁,显示的时候再重建: <div id="on ...
- git-tag 标签相关操作
标签可以针对某一时间点的版本做标记,常用于版本发布. 列出标签 $ git tag # 在控制台打印出当前仓库的所有标签$ git tag -l ‘v0.1.*’ # 搜索符合模式的标签 打标签 gi ...
- rocketmq安装与基本操作
如果不是因为政治原因,就rocketmq的社区活跃度.版本.特性和文档完善度,我是无论如何也不会使用rocketmq的. rocketmq严格意义上并不支持高可靠性,因为其持久化只支持异步,有另外一个 ...
- Python学习基础(二)——集合 深浅拷贝 函数
集合 # 集合 ''' 集合是无序不重复的 ''' # 创建列表 l = list((1, 1, 1)) l1 = [1, 1, 1] print(l) print(l1) print("* ...
- Installing Moses on Ubuntu 16.04
Installing Moses on Ubuntu 16.04 The process of installation To install requirements sudo apt-get in ...
- SqlServer字符串拼接
ID Name 2 小红 2 小明 2 小青 3 大红 3 大明 3 大青 有一张这样的表,现在要达到 把ID为2的Name合拼成一行显示出来: step1:建函数 CREATE FUNCTI ...
- 前端 --- 2 css
一. CSS的几种引入方式 1.行内样式 2.内部样式 写在网页的<head></head>标签对的<style></style>标签对中 3.外部样式 ...
- Flask学习【第9篇】:Flask-script组件
Flask Script扩展提供向Flask插入外部脚本的功能,包括运行一个开发用的服务器,一个定制的Python shell,设置数据库的脚本,cronjobs,及其他运行在web应用之外的命令行任 ...