前言

相比大家也在开发中是非常喜欢用ORM的。今天就来介绍一下EntityFrameworkCore的使用方法。

自从EF Core升级到1.1之后,确实变化挺大的。如果没试过真的不知道坑是挺多的。今天将结合Asp.net Core 、EF Core 1.1和SqlServer来做个简单介绍,顺便把遇到的坑记录一下,以免以后忘记了。

项目结构

1.Asp.net core的WebApi(EFcoreDemo.Api)

2.EF core的standard libray (EFcoreDemo.DAL)

首先是用cmd新建解决方案,就是sln文件啦,输入以下脚本:

dotnet new sln -o EFcoreDemo
cd EFcoreDemo

之后分别建立上面说到的2个项目,运行下面2个脚本:

dotnet new classlib -o EFcoreDemo.DAL
dotnet new webapi -o EFcoreDemo.Api

加了这2个项目之后,其实解决方案上面还是没有这2个项目的,要运行下面的2个脚本:

dotnet sln add EFcoreDemo.DAL/EFcoreDemo.DAL.csproj
dotnet sln add EFcoreDemo.Api/EFcoreDemo.Api.csproj

这里要对项目的依赖关系进行处理,打开EFcoreDemo.Api.csproj文件,修改成这样

<Project Sdk="Microsoft.NET.Sdk.Web">

  <PropertyGroup>
<TargetFramework>netcoreapp1.1</TargetFramework>
</PropertyGroup> <ItemGroup>
<Folder Include="wwwroot\" />
</ItemGroup> <ItemGroup>
<PackageReference Include="Microsoft.AspNetCore" Version="1.1.1" />
<PackageReference Include="Microsoft.AspNetCore.Mvc" Version="1.1.2" />
<PackageReference Include="Microsoft.Extensions.Logging.Debug" Version="1.1.1" />
</ItemGroup> <ItemGroup>
<ProjectReference Include="../EFcoreDemo.DAL/EFcoreDemo.DAL.csproj" />
</ItemGroup>
</Project>

之后运行一下dotnet restore恢复一下。

来到这里,项目结构就完成了。

加入EntityFramework Core

大家都知道.net core的引用都是要修改csproj文件的。然后我们在Api和DAL上都分别加上下面的引用

<PackageReference Include="Microsoft.EntityFrameworkCore" Version="1.1.2" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Relational" Version="1.1.2" />
<PackageReference Include="Microsoft.EntityFrameworkCore.SqlServer" Version="1.1.2" />
<PackageReference Include="Microsoft.EntityFrameworkCore.Tools" Version="1.1.1" />

但是加了引用还是不够的,还需要加入EF core的工具。这里就变化比较大了。在EF core 1.0时我们只需要把Microsoft.EntityFrameworkCore.Tools加到Tools节点就可以了。但是在1.1的时候改了,变成Microsoft.EntityFrameworkCore.Tools.DotNet这个工具包。然后他的添加方法是这样的,把下面的整个代码加入到2个.csproj文件的Project节点下。

<ItemGroup>
<DotNetCliToolReference Include="Microsoft.EntityFrameworkCore.Tools.DotNet" Version="1.0.0" />
</ItemGroup>

好了之后,分别对Api和DAL两个项目走一下dotnet restore

构建数据库

构建数据库实体,这里就简单处理先,下面是实体的所有代码

    public interface IEntityBase
{
int Id { get; set; }
} public class EntityBase : IEntityBase
{
[Key]
public virtual int Id { get; set; }
} [Table("People")]
public class People : EntityBase
{
[StringLength()]
public string Name { get; set; } public int Age { get; set; }
}

之后建立DbContext,

    public class MyDbContext : DbContext
{
public DbSet<People> Peoples { get; set; } protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
base.OnConfiguring(optionsBuilder);
optionsBuilder.UseSqlServer(@"Data Source=.\sqlexpress;Initial Catalog=mydb;Integrated Security=SSPI;");
} }

看起来一切就绪了,好的我们试试能生成migration文件不。根据以往的经验,需要在DAL的项目下走ef的脚本。按照ef tools的方案走以下脚本:

dotnet ef migrations add V001

然后提示了一串信息,但是到项目里面看,确实已经把migration文件加进来了

提示信息大概就说为了避免运行时的错误,最好能在加migration文件的时候,指定哪个项目作为启动项目。

好既然这样,我们就试试看怎么用Api项目作为启动,正确引用EF core。(上一步生成的migration文件先手动删除啦)

我们在Api里面的startup.cs文件中的ConfigureServices方案按照EF core的方法,加入以下代码:

services.AddDbContext<MyDbContext>(option =>
{
option.UseSqlServer(@"Data Source=.\sqlexpress;Initial Catalog=mydb;Integrated Security=SSPI;");
});

运行以下脚本

dotnet ef migrations add V001 --startup-project ../EFcoreDemo.Api

没想到这么容易就成功了,而且项目的migration文件也生成了。

之后我们运行以下脚本,看看是不是能真正建立数据库

dotnet ef database update --startup-project ../EFcoreDemo.Api

最终查看sql server,已经能正确建立数据库了。

到此,基本已经完成了

最后

之前在网络上有一些文章也有教怎么使用EF core 1.1, 但是他们有一个共同的缺点,就是所有Migration文件都是存放在Api项目内的,而不是DAL内。

所以那些方法不是真正能应用在项目中的。试想一下,如果migration在Api的项目中,这样DAL岂不是必须要有Api项目,才能记录完整的数据库迁移历史?这肯定是不正确的

Asp.net Core 使用 EntityFrameworkCore 1.1的更多相关文章

  1. ASP.NET Core使用EntityFrameworkCore CodeFrist

    1,安装环境: 如果是VS2015,确保已经升级至 update3或以上 .net core sdk (https://www.microsoft.com/net/download/core) vs2 ...

  2. Asp.Net Core 项目实战之权限管理系统(0) 无中生有

    0 Asp.Net Core 项目实战之权限管理系统(0) 无中生有 1 Asp.Net Core 项目实战之权限管理系统(1) 使用AdminLTE搭建前端 2 Asp.Net Core 项目实战之 ...

  3. ASP.NET Core 开发 - Entity Framework (EF) Core

    EF Core 1.0 Database First http://www.cnblogs.com/linezero/p/EFCoreDBFirst.html ASP.NET Core 开发 - En ...

  4. ASP.NET Core WebAPI 开发-新建WebAPI项目

    ASP.NET Core WebAPI 开发-新建WebAPI项目, ASP.NET Core 1.0 RC2 即将发布,我们现在来学习一下 ASP.NET Core WebAPI开发. 网上已经有泄 ...

  5. ASP.NET Core WebAPI 开发-新建WebAPI项目 转

    转 http://www.cnblogs.com/linezero/p/5497472.html ASP.NET Core WebAPI 开发-新建WebAPI项目   ASP.NET Core We ...

  6. ASP.NET Core学习之五 EntityFrameworkCore

    目的:运用EntityFrameworkCore ,使用codefirst开发 一.创建web项目 创建一个不进行身份验证的   ASP.NET Core Web Application (.NET ...

  7. Asp.net Core 2.0+EntityFrameWorkCore 2.0添加数据迁移

    Asp.net Core 由于依赖注入的广泛使用,配置数据迁移,与Asp.net大不相同,本篇介绍一下Asp.net Core添加数据迁移的过程 添加Nuget包 Install-Package Mi ...

  8. ASP.NET Core 3.1 WebApi+JWT+Swagger+EntityFrameworkCore构建REST API

    一.准备 使用vs2019新建ASP.NET Core Web应用程序,选用api模板: 安装相关的NuGet包: 二.编码 首先编写数据库模型: 用户表 User.cs: public class ...

  9. ASP.NET Core 1.0 开发记录

    官方资料: https://github.com/dotnet/core https://docs.microsoft.com/en-us/aspnet/core https://docs.micro ...

随机推荐

  1. MySQL 及 SQL 注入与防范方法

    所谓SQL注入,就是通过把SQL命令插入到Web表单递交或输入域名或页面请求的查询字符串,最终达到欺骗服务器执行恶意的SQL命令. 我们永远不要信任用户的输入,我们必须认定用户输入的数据都是不安全的, ...

  2. Oracle数据库设计规范建议

    Oracle数据库设计规范建议 1 目的 本规范的主要目的是希望规范数据库设计,尽量提前避免由于数据库设计不当而产生的麻烦:同时好的规范,在执行的时候可以培养出好的习惯,好的习惯是软件质量的很好的保证 ...

  3. CSS控制表格嵌套

    网页设计应用中,当我们不能完全放弃表格的使用时,为了达到预期的效果,不免要用到表格嵌套(特别是多层嵌套)方式来进行布局.可能很多同仁都遇到过这样的问题,为了达到显示效果要为每一个(每一层)的表格写不同 ...

  4. 分享知识-快乐自己:Shiro 退出登陆清空缓存实现

    shiro是一个被广泛使用的安全层框架,通过xml配置方式与spring无缝对接,用户的登陆/退出/权限控制/Cookie等管理系统基础功能交给shiro来管理. 一般,在JavaWEB管理平台系统时 ...

  5. 用一句SQL取出第 m 条到第 n 条记录的方法

    1 --从Table 表中取出第 m 条到第 n 条的记录:(Not In 版本)2 3 SELECT TOP n-m+1 * 4 FROM Table 5 WHERE (id NOT IN (SEL ...

  6. jenkins-小知识点

    如果想停止jenkins运行 控制面板-服务-查看本地服务-选中jenkins 1.启动类型改为手动 2.改为禁止 使用的时候,每次都改一下状态

  7. WampServer 2.5设置外网访问/局域网手机访问(403 Forbidden错误解决方法)

    安装好wamp后,想用手机通过局域访问电脑上wamp下的网页,结果出现如下提示. (403 Forbidden)错误 1.打开http.conf文件 2.找到下图中红色方框中的onlineofflin ...

  8. linux命令学习笔记(0):man命令

    Linux提供了丰富的帮助手册,当你需要查看某个命令的参数时不必到处上网查找,只要man一下即可. Linux的man手册共有以下几个章节: 代號 代表內容 使用者在shell中可以操作的指令或可执行 ...

  9. ffmpeg处理RTMP流媒体的命令和发送流媒体的命令(UDP,RTP,RTMP)

    将文件当做直播送至live ffmpeg -re -i localFile.mp4 -c copy -f flv rtmp://server/live/streamName     re限制输出速率, ...

  10. 用VLC做流媒体服务器

    VLC确切来说只是个播放器,是videolan的开源产品,videolan原来还有一个VLM,是服务器端,专门用来做流媒体服务器的,但是现在VLM的功能已经都集成进VLC了,所以也就可以用VLC来做流 ...