EF一次请求公用一个实例

应用场景:

  我们在程序开发时,对数据库的操作是必不可少的部分,常规的做法是直接使用Using()语句块,在用完后立即释放连接资源,这种做法在桌面应用程序中毫无问题,但是在Web程序中,尤其是在当今大数据,高访问量的时代,响应速度成为了一个网站好坏的很作重要的衡量标准,我们也知道sqlserver的数据库连接其底层也是用socket技术实现的,那么就造成了数据库连接资源非常宝贵,那么怎么才能在web程序中充分利用这个宝贵的连接资源呢?

解决方案:

 

 1 public class DbContextHelper
 2     {
 3         public static MyDbContext GetCurrentDbContext()
 4         {
 5             #region HttpContext 方式(内部有CallContext实现)
 6             //MyDbContext dbContext = HttpContext.Current.Items["MyDbContext"] as MyDbContext;
 7             //if (dbContext == null)
 8             //{
 9             //    dbContext = new MyDbContext();
10             //    HttpContext.Current.Items.Add("MyDbContext", dbContext);
11             //}
12             //return dbContext;
13             #endregion
14 
15             #region CallContex直接实现
16             MyDbContext dbContext = CallContext.GetData("MyDbContext") as MyDbContext;
17             if (dbContext == null)
18             {
19                 dbContext = new MyDbContext();
20                 CallContext.SetData("MyDbContext", dbContext);
21             }
22             return dbContext;
23             #endregion
24         }
25     }
26     public class MyDbContext
27     {
28     }

 

转载于:https://www.cnblogs.com/saodiseng2015/p/5583281.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值