osharp3 整合 dbcontextscope 文章2 将dbcontext的创建收回到ioc管理
osharp3 整合 dbcontextscope 后,,dbcontextscope 对dbcontext管理的很好,做到,用到时创建,不用时销毁,下面看一个 trace
- aspx.page: End PreInit
- aspx.page: Begin Init
- aspx.page: End Init
- aspx.page: Begin InitComplete
- aspx.page: End InitComplete
- aspx.page: Begin PreLoad
- aspx.page: End PreLoad
- aspx.page: Begin Load
- trace OnLoad: SetControlInPage begin 根据权限标记,控制页面控件的显示和隐藏
- trace OnLoad: RegBtnClick begin 根据权限标记,注册按钮事件
- : DefaultDbContext ctor
- object name: System.String
- caller name: CanDoo.Data.Entity.Interceptors.EFIntercepterLogging
- member name: ReaderExecuted
- source line number: 94
- time: 20160705 071119 8589791
- message: ReaderExecuted执行时间:0 毫秒 \r\n -->ReaderExecuted.Command:\r\nSELECT
- [Extent1].[Id] AS [Id],
- [Extent1].[CreatedTime] AS [CreatedTime],
- [Extent1].[Code] AS [Code],
- [Extent1].[SortIndex] AS [SortIndex],
- [Extent1].[Remark] AS [Remark],
- [Extent1].[ParentId] AS [ParentId],
- [Extent1].[Name] AS [Name]
- FROM [dbo].[sys_Department] AS [Extent1]
- : DefaultDbContext Dispose
- aspx.page: End Load
- aspx.page: Begin LoadComplete
- aspx.page: End LoadComplete
- aspx.page: Begin PreRender
- aspx.page: End PreRender
- aspx.page: Begin PreRenderComplete
- aspx.page: End PreRenderComplete
- aspx.page: Begin SaveState
- aspx.page: End SaveState
- aspx.page: Begin SaveStateComplete
- aspx.page: End SaveStateComplete
- aspx.page: Begin Render
- aspx.page: End Render
但dbcontext默认是由dbcontextscope创建的,所以,我们的ioc就不能对dbcontext建行注入
不过它留了个接口 IDbContextFactory
- public interface IDbContextFactory
- {
- TDbContext CreateDbContext<TDbContext>() where TDbContext : DbContext;
- DbContext CreateDbContext(Type requestedType);
- }
为了在dbcontext注入属性,,我通过这个接口,
将dbcontext的创建收回到ioc,实现这个接口
- public class CandooDbContextFactory : IDbContextFactory
- {
- private IServiceProvider _provider;
- public CandooDbContextFactory(IServiceProvider provider)
- {
- _provider = provider;
- }
- public TDbContext CreateDbContext<TDbContext>() where TDbContext : DbContext
- {
- return (TDbContext)_provider.GetService(typeof(TDbContext));
- }
- public DbContext CreateDbContext(Type requestedType)
- {
- return (DbContext)_provider.GetService(requestedType);
- }
- }
修改Startup注入配置
- services.AddTransient<DefaultDbContext>();
- services.AddTransient<LoggingDbContext>();
- services.AddScoped<IDbContextFactory, CandooDbContextFactory>();
相关文章:
osharp3使用经验:整合DbContextScope 文章 1 http://www.cnblogs.com/shiningrise/p/oshap3_DbContextScope.html
https://github.com/mehdime/DbContextScope
https://github.com/i66soft/osharp
osharp3 整合 dbcontextscope 文章2 将dbcontext的创建收回到ioc管理的更多相关文章
- osharp3使用经验:整合DbContextScope 文章 1
osharp3的事务处理是跳过savechangeing方法来控制的,没有DbContextScope专业 DbContextScope管理dbcontext的优劣本文不讨论 整合过程: 1.在.Da ...
- Javascript - ExtJs - 整合百度文章编辑器
ExtJs - 整合百度文章编辑器(ExtJs UEditor) 第一步:去官网下载最新版本的UEditor,UEditor下载. 第二步:在编辑器根目录创建一个Extjs-Editor.js,录入以 ...
- 解决DbContext对象创建问题
解决DbContext对象创建问题 方法一: 使用CallContext public class BaseController : Controller { public MyContext db ...
- dbcontext实例创建问题
dbcontext初始化 Private DemoContext db=new DemoContext (): 问题:什么时候释放db对象? 使用Using()方法中创建,每次调用会造成频繁的连接关闭 ...
- 潭州课堂25班:Ph201805201 django 项目 第三十四课 后台文章标签更新功能 ,创建功能实现(课堂笔记)
g更改标签:,前台要向后台传来 id, name, 对标签进行校验:标签不能为空,标签是否已经存在, 流程: def put(self, request, tag_id): ''' 更改标签 :par ...
- EF Core 2.0中Transaction事务会对DbContext底层创建和关闭数据库连接的行为有所影响
数据库 我们先在SQL Server数据库中建立一个Book表: CREATE TABLE [dbo].[Book]( ,) NOT NULL, ) NULL, ) NULL, ) NULL, [Cr ...
- ssh整合思想 Spring与Hibernate的整合 项目在服务器启动则自动创建数据库表
Spring整合Hibernate Spring的Web项目中,web.xml文件会自动加载,以出现欢迎首页.也可以在这个文件中对Spring的配置文件进行监听,自启动配置文件, 以及之前Struts ...
- 零基础学习java------39---------json格式交互,Restful(不懂),静态资源映射,SSM整合(ssm整合思想,application.xml文件详解(声明式事务管理),)
一. json格式交互(知道) 1 . 回顾ajax基本语法 $.ajax({ url:"", // 请求的后台路径 data:{"":"" ...
- ASP.NET MVC with Entity Framework and CSS一书翻译系列文章之第一章:创建基本的MVC Web站点
在这一章中,我们将学习如何使用基架快速搭建和运行一个简单的Microsoft ASP.NET MVC Web站点.在我们马上投入学习和编码之前,我们首先了解一些有关ASP.NET MVC和Entity ...
随机推荐
- JS 弹窗到右下角
<div id="msg_win" style="display: block; top: 490px; visibility: visible; opacity: ...
- ORA-29538、ORA-29532、ORA-29913问题解决
问题一:ERROR at line 1: ORA-29538: Java not installed解决方法1.检查有没有安装JAVA组件select * from v$option t where ...
- BZOJ 1124: [POI2008]枪战Maf
1124: [POI2008]枪战Maf Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 617 Solved: 236[Submit][Status ...
- 【faster-rcnn】训练自己的数据集时的坑
既然faster-rcnn原版发表时候是matlab版代码,那就用matlab版代码吧!不过遇到的坑挺多的,不知道python版会不会好一点. ======= update ========= 总体上 ...
- 【BZOJ-1055】玩具取名 区间DP
1055: [HAOI2008]玩具取名 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1560 Solved: 907[Submit][Statu ...
- Windows Server 2012及以上安装IIS的步骤
已经和2008安装时有着明显区别,如题的安装步骤如下: 这里需要注意的是,选择了[Web 服务器(IIS)支持]后可能会弹出选择的界面,到时也一起全选,这里由于是已经安装了,所以没弹出. 说明:上面根 ...
- CSS中的a标签几个访问状态记录
a:link {color: #FF0000} /* 未访问的链接 */a:visited {color: #00FF00} /* 已访问的链接 */a:hover {color: #FF0 ...
- hdu3932 模拟退火
模拟退火绝对是从OI--ACM以来接触过的所有算法里面最黑科技的orz 题意:地上有一堆hole,要找一个点,使得(距离该点最远的hole的距离)最小. sol:本来想套昨天的模拟退火模板,初值(0, ...
- 重新认识unicode和utf8编码
重新认识unicode和utf8编码 直到今天,准确的说是刚才,我才知道UTF-8编码和Unicode编码是不一样的,是有区别的囧 他们之间是有一定的联系的,看看他们的区别: UTF-8的长度是不一定 ...
- Androidstudio 的svn配置 需要忽略的目录