tnblog
首页
视频
资源
登录

Net Core使用EF之DB First+注入自动生成数据库

4244人阅读 2019/12/24 11:32 总访问:37294 评论:0 收藏:0 手机
分类: .NET Core

   上次我们做了单点登录和注销登录。那时候登录的数据都是死的,我们要想从数据库获取数据,

   当然就要用ef 生成,获取数据。

 

一,新建一个.net core 的mvc项目


新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖

注意:所以依赖注入的命令不要放在项目里,要选择放入自己需要生成数据的类库里。



二,需要使用工具的Nuget包管理器添加EF的依赖。

Install-Package Microsoft.EntityFrameworkCore.SqlServer


三.如果是使用db first,需要根据数据库生成model,就还需要使用命令添加两个依赖

Install-Package Microsoft.EntityFrameworkCore.Tools    Install-Package Microsoft.EntityFrameworkCore.SqlServer.Design

四.相关依赖注入成功之后,就可以再根据一个命令从数据库生成model了

Scaffold-DbContext "Server=.;Database=Food;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models

  注意:这里的Database=数据库的名称



 依赖注入安装这个依赖的时候他会提示:你的版本太低,

因为系统是win7,powershell版本太低了,不支持这个命令,需要安装3.0以上的powershell版本才行

  不用慌,我们这里有网站教程,大家可以查看教程升级版本。

  https://www.cnblogs.com/tshaoguo/p/10142743.html


注意:我们在存放Windows6.1-KB2506143-x64.cab包的时候,要对应自己电脑的路径存放使用哦,不要直接复制网站路径。


然后我们再次使用命令·即可:

 Scaffold-DbContext "Server=.;Database=HouseDB;Trusted_Connection=True;" Microsoft.EntityFrameworkCore.SqlServer -OutputDir Models

还有一种情况,就是有些电脑的版本和powershell3.0版本有些不太兼容。当你在注入生成model的命令之后会报版本冲突问题。

没有报错的可以忽略此段内容。


 不用慌,我们也有解决方案。就是在Nu Get 包管理器的解决方案Nu Get程序包配置一下这几个版本为2.1.0。

Microsoft.EntityFrameworkCoreMicrosoft.EntityFrameworkCore.SqlServerMicrosoft.EntityFrameworkCore.ToolsMicrosoft.VisualStudio.Web.CodeGeneration.Design以第一个为例,配置,图如下:

  

   四个都是一样的分别复制后,在NuGet解决方案里搜索,然后都配置为2.1.0版本,然后安装就行。效果图如下:

   

 

我当时就是遇到第二种情况,后来重做登录也是报版本冲突问题,后面就重新安装版本后就好啦,不容易啊。


好啦,现在解决版本问题,ef也依赖注入完成,我们就需要获取数据库的数据了,这里net core 里的ef 和net mvc 还是有区别的哦。


当我们得到model数据层之后,就需要在类库封装用户登录的方法。

  


  定义数据源,封装同步和异步登录的方法,代码如下:

 public class UserDAL : IUserDAL    {        private readonly HouseDBContext _houseDBContext;        //构造函数,得到数据源        public UserDAL(HouseDBContext MyhouseDBContext)        {            _houseDBContext = MyhouseDBContext;        }        //用户登录的方法 同步        public Customers Login(string username, string password)        {            Customers customer = _houseDBContext.Customers.Where(a => a.LoginName == username && a.Password == password).FirstOrDefault();            return customer;        }        //用户登录的方法  :异步        public Task<Customers> LoginAsync(string username, string password)        {            Task.Run(() =>            {                Customers customer = _houseDBContext.Customers.Where(a => a.LoginName == username && a.Password == password).FirstOrDefault();                return customer;            });            return null;        }


   大家是不是发现我们这个类还继承了一个借口:IUserDAL。
  1,就是我们需要在类库里新建两个文件夹,Implemts,Interface,把UserDAL类移到Implemts后,选择UserDAL类右键快速操作和重构接口

  2,把重构的类移到Interface的文件夹中。然后更改两个的命名空间即可,如图。

   

   

 

 五.现在我们需要在项目的Startup.cs服务的ConfigureServices方法里配置连接数据库

 

   服务添加用户继承的接口:配置依赖注入的关系    services.AddTransient<IUserDAL, UserDAL>();     services.AddDbContext<HouseDBContext>(option => {          option.UseSqlServer("Data Source =.; Initial Catalog = HouseDB; User ID = sa; Password = 123456"); });

注意:连接数据库的配置不能错了哦。


最后一步。我们需要在登录项目的Account控制器下获取数据.


tip:因为net core 不允许实例化对象,所以只有定义获取值。

 

 我们调用同步登录的方法,验证登录。代码如下图:

  


  到这一步终于完成啦,好累好累。现在大家可以登录试试,如果输入错误的用户名或密码就会报错哦,大家也可以自己调试一下过程,

 毕竟好不容易做出来的,虽然外表看上去只是一个小小的ef获取数据登录。哈哈!


 不懂的,欢迎在评论区讨论问题哦。


评价
黑发不知勤学早,白发方悔读书迟......
排名
6
文章
6
粉丝
16
评论
8
{{item.articleTitle}}
{{item.blogName}} : {{item.content}}
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2024TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
欢迎加群交流技术