tnblog
首页
登录

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

92人阅读 2019/12/21 16:42 总访问:2743 评论:3 手机 收藏
分类: .NET Core

人的一生中至少要有两次冲动,一次为奋不顾身的爱情,一次为说走就走的旅行

那一瞬间,仿佛突然被闪电击中了一般,产生了巨大的共鸣感。

是啊,扪心自问一下,我们的人生是不是总是被太多的东西束缚住了脚步?我们是不是被太多的按部就班慢慢的,慢慢的磨合成了活在框框里的人?是不是一旦出了框框就会无所适从?

对于大多数人来说,随着年龄的增长,那些说做就做的冲动热血已然被打磨成了温吞的白开水,做事更多的是遵循三思而后行。试问,这样的人生算了无遗憾吗?

但是话说到这里,我虽然赞同那句话,但是如果真让我这么做,我还是会考虑很多,前后左右徘徊不定。我自问是做不到那么潇洒的摆脱世俗的牵挂,去做我想做的事情。

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

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

 

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


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

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



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

Install-Package Microsoft.EntityFrameworkCore.SqlServer -version 2.1.0


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

Install-Package Microsoft.EntityFrameworkCore.Tools -version 2.1.0    
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.EntityFrameworkCore
Microsoft.EntityFrameworkCore.SqlServer
Microsoft.EntityFrameworkCore.Tools
Microsoft.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-2020TNBLOG.NET