1
.DbContext怎么在Asp.mvc中使如何实例化
public class Repository { //实例化EF容器:有弊端。一个线程里可能会创建多个DbContext //DbContext db = new DbContext(); //改造:保证一个请求线程中只有一份EF容器(你要明白:一个url请求到服务器,IIS就开一个线程去处理) protected DbContext GetDbContext { get { //向线程缓存中查询,如果返回的是null,则创建,同时存入到这个线程缓存中 //注意的是线程缓存CallContext,而不是我们熟悉的HttpRuntime.cache。意味着这个DbContext对象在这个线程内能被其他方法共享。 object efDbContext = CallContext.GetData("DbContext"); if (efDbContext == null) { efDbContext = new DbContext(); //存入到这个线程缓存中 CallContext.SetData("DbContext", efDbContext); } return efDbContext as DbContext; } } }
2.为什么你要using 或dispose掉DbContext ?
是担心数据库连接没有释放?还是担心DbContext占用过多资源呢?
首先担心数据库连接没有释放肯定是多余的,因为DbContext在SaveChanges完成后会释放掉打开的数据库连接。
可以反编译一下SaveChages的源码。
担心DbContext占用过多资源也是多余的,有GC回收。