tnblog
首页
视频
资源
登录

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

5476人阅读 2019/12/21 16:42 总访问:400877 评论:6 收藏:1 手机
分类: .NET Core

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

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

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

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

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

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

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

 

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


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

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



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

  1. Install-Package Microsoft.EntityFrameworkCore.SqlServer -version 2.1.0


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

  1. Install-Package Microsoft.EntityFrameworkCore.Tools -version 2.1.0    
  2. Install-Package Microsoft.EntityFrameworkCore.SqlServer.Design

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

  1. 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包的时候,要对应自己电脑的路径存放使用哦,不要直接复制网站路径。


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

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

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

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


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

  1. Microsoft.EntityFrameworkCore
  2. Microsoft.EntityFrameworkCore.SqlServer
  3. Microsoft.EntityFrameworkCore.Tools
  4. Microsoft.VisualStudio.Web.CodeGeneration.Design
  5. 以第一个为例,配置,图如下:

 

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

  

 

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


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


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

 


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

  1.  public class UserDAL : IUserDAL
  2.     {
  3.         private readonly HouseDBContext _houseDBContext;
  4.         //构造函数,得到数据源
  5.         public UserDAL(HouseDBContext MyhouseDBContext)
  6.         {
  7.             _houseDBContext = MyhouseDBContext;
  8.         }
  9.         //用户登录的方法 同步
  10.         public Customers Login(string username, string password)
  11.         {
  12.             Customers customer = _houseDBContext.Customers.Where(a => a.LoginName == username && a.Password == password).FirstOrDefault();
  13.             return customer;
  14.         }
  15.         //用户登录的方法  :异步
  16.         public Task<Customers> LoginAsync(string username, string password)
  17.         {
  18.             Task.Run(() =>
  19.             {
  20.                 Customers customer = _houseDBContext.Customers.Where(a => a.LoginName == username && a.Password == password).FirstOrDefault();
  21.                 return customer;
  22.             });
  23.             return null;
  24.         }


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

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

  

  

 

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

 

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

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


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


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

 

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

 


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

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


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




评价

剑轩

2019/12/21 17:00:03

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

陪你听风:@剑轩想多远,走多远。身体健康的时候,把每一分钟都活到极致!-------这是一位驴友经典话语,当然也是我的心声!

2019/12/21 17:24:20 回复

剑轩:@陪你听风说得好哇

2019/12/22 13:45:19 回复

剑轩

2020/4/16 14:39:35

哈哈现在看到开头那句话还是很喜欢!

陪你听风:@剑轩我相信世界上有真正的感同身受,哈哈,,,

2020/4/16 15:03:38 回复

剑轩:@陪你听风感同身受给你救赎热望~

2020/4/16 16:41:43 回复

net core 使用 EF Code First

下面这些内容很老了看这篇:https://www.tnblog.net/aojiancc2/article/details/5365 项目使用多层,把数据库访问...

.net mvc分部页,.net core分部页

.net分部页的三种方式第一种:@Html.Partial(&quot;_分部页&quot;)第二种:@{ Html.RenderPartial(&quot;分部页&quot;);}...

StackExchange.redis操作redis(net core支持)

官方git开源地址https://github.com/StackExchange/StackExchange.Redis官方文档在docs里边都是官方的文档通过nuget命令下...

.net core 使用session

tip:net core 2.2后可以直接启用session了,不用在自己添加一次session依赖,本身就添加了使用nuget添加引用Microsoft.AspN...

通俗易懂,什么是.net?什么是.net Framework?什么是.net core?

朋友圈@蓝羽 看到一篇文章写的太详细太通俗了,搬过来细细看完,保证你对.NET有个新的认识理解原文地址:https://www.cnblo...

asp.net core2.0 依赖注入 AddTransient与AddScoped的区别

asp.net core主要提供了三种依赖注入的方式其中AddTransient与AddSingleton比较好区别AddTransient瞬时模式:每次都获取一...

.net core 使用 Kestrel

Kestrel介绍 Kestrel是一个基于libuv的跨平台web服务器 在.net core项目中就可以不一定要发布在iis下面了Kestrel体验可以使...

net core使用cookie

net core中可以使用传统的cookie也可以使用加密的cookieNET CORE中使用传统cookie设置:HttpContext.Response.Cookies.Appe...

net core项目结构简单分析

一:wwwrootwwwroot用于存放网站的静态资源,例如css,js,图片与相关的前端插件等lib主要是第三方的插件,例如微软默认引用...

net core使用EFDB First

一.新建一个.net core的MVC项目新建好项目后,不能像以前一样直接在新建项中添加ef了,需要用命令在添加ef的依赖二.使用Nug...

.net core使用requestresponse下载文件下载excel等

使用request获取内容net core中request没有直接的索引方法,需要点里边的Query,或者formstringbase64=Request.Form[&quot;f...

iframe自适应高度与配合net core使用

去掉iframe边框frameborder=&quot;0&quot;去掉滚动条scrolling=&quot;no&quot;iframe 自适应高度如果内容是固定的,那么就...

net core启动报错Unable to configure HTTPS endpoint. No server certificate was specified

这是因为net core2.1默认使用的https,如果使用Kestrel web服务器的话没有安装证书就会报这个错其实仔细看他的错误提示,其...

net core使用url编码与解码操作

net core中暂时还没有以前asp.net与mvc中的server对象。获取url的编码与解码操作不能使用以前的server对象来获取。使用的是...

下载net core

官方下载地址:https://dotnet.microsoft.com/download 进来之后就可以看到最新的下载版本可以直接点击下载,也可以下载其...

net core使用依赖注入来装载EF的上下文对象

妹子情人节快乐~.net core中用了不少的依赖注入,官方文档中也推荐使用。这样使用依赖注入来管理ef对象,还是比较科学,比如...
你之所以觉得时间一年比一年过得快,是因为时间对你一年比一年重要。
排名
13
文章
64
粉丝
20
评论
30
MUI框架页面间的传值指针
XingDy姐 : 不错哦
MUI框架页面间的传值指针
剑轩 : 接口的真实地址可以用xx/yy什么的代替哦,真实地址还是隐藏一下好
.NET EF 用户按钮权限
YOU : 可以,在写文章的时候,有需要写代码的地方,可以选择编辑器上的代...
.NET EF 用户按钮权限
剑轩 : 哈哈哈哈,你这个追女生的逻辑
EF三种模式解析
剑轩 : 好文采!
重要sql语句和linq,lamdba分组条件查询语句
剑轩 : 开头那句诗句写得很好哇!
ICP备案 :渝ICP备18016597号-1
网站信息:2018-2025TNBLOG.NET
技术交流:群号656732739
联系我们:contact@tnblog.net
公网安备:50010702506256
欢迎加群交流技术
Why so serious?