排名
6
文章
6
粉丝
16
评论
8
{{item.articleTitle}}
{{item.blogName}} : {{item.content}}
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:
50010702506256
50010702506256
欢迎加群交流技术
分类:
.NET Core

妹子情人节快乐~
.net core中用了不少的依赖注入,官方文档中也推荐使用。
这样使用依赖注入来管理ef对象,还是比较科学,比如想要单利就很简单了
1:删除方法
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
//#warning To protect potentially sensitive information in your connection string, you should move it out of source code. See http://go.microsoft.com/fwlink/?LinkId=723263 for guidance on storing connection strings.
optionsBuilder.UseSqlServer(@"Server=.;Database=Food;Trusted_Connection=True;");
}2:添加方法
public FoodContext(DbContextOptions<FoodContext> options)
: base(options)
{
}添加的是一个构造函数用于构造函数注入(这个方法在新版的时候会自动加入)
3:在startup.cs的ConfigureServices方法中添加依赖注入
public void ConfigureServices(IServiceCollection services)
{
// Add framework services.
services.AddMvc();
services.AddDbContext<FoodContext>(option => {
option.UseSqlServer("Data Source =.; Initial Catalog = EFCore_dbfirst; User ID = sa; Password = sa.123");
});
}注:usersqlserver是一个扩展方法,需要添加ef core的引用using Microsoft.EntityFrameworkCore;
4:使用的时候就不能直接去实例化了否则会报错找不到上下文对象

应该使用注入的方式去获取ef对象,例如构造函数注入
private CNBlog_ServerContext ef;
public ArticleDAL(CNBlog_ServerContext context) //通过依赖注入得到实例
{
ef = context;
}但是如果你这个DAL类是直接实例化的ef也无法被成功的注入,因为你直接实例化调用的是无参的构造函数,
没有为他注入,所以我们应该使用依赖注入来注入对应的DAL类
private IArticleDAL _articledal;
public RelatedArticleController(IArticleDAL articledal) //通过依赖注入得到数据访问层实例
{
_articledal = articledal;
}这样依赖注入在注入DAL层对应的类的时候发现该类还有一个需要注入的对象,就会被他自动注入了
当然注入的方式除了构造函数注入我们还可以使用其他的注入方式
欢迎加群讨论技术,1群:677373950(满了,可以加,但通过不了),2群:656732739。有需要软件开发,或者学习软件技术的朋友可以和我联系~(Q:815170684)
评价