项目地址:https://gitee.com/dhclly/IceDog.EFCore

项目介绍

对 Microsoft EntityFramework Core 框架的练习测试

参考文档教程

项目简介

IceDog.EFCore.Cmd.CodeFirst

这是一个 EFCore Code First 的示例项目,详情在项目里面的readme里面

配置连接字符串在 IceDog.EFCore\src\IceDog.EFCore.Cmd\Context\BloggingContext.cs

IceDog.EFCore.Cmd.DBFirst

这是一个 EFCore DB First 的示例项目,详情在项目里面的readme里面

IceDog.EFCore.Cmd.OfficalDemo

这个项目是微软官方的快速入门例子本人的练习,可供大家参考,详情在项目里面的readme里面。

官方教程地址:https://docs.microsoft.com/zh-cn/ef/core/

IceDog.EFCore.WebApiServer

这是 EF Core 在 WebApi项目里面的应用,和一般项目不同就在于配置数据库连接不在Context里面,而是在

IceDog.EFCore\src\IceDog.EFCore.WebApiServer\Startup.cs里面的ConfigureServices里面

详情在项目里面的readme里面

IceDog.EFCore.ContosoUniversity

此项目是实现如下文档的内容,教程看官方的即可

ASP.NET Core Razor 页面和 EF Core - 教程系列

https://docs.microsoft.com/zh-cn/aspnet/core/data/ef-rp/?view=aspnetcore-2.2

参考代码 https://github.com/aspnet/Docs/tree/master/aspnetcore/data/ef-rp/intro/samples

详情在项目里面的readme里面

常用的EF Core驱动

以下驱动都可以在nuget找到,MySql/MariaDB 推荐使用Pomelo EF Core组件,因为官方的目前可能存在bug,Pomelo EF Core同样是微软官方所推荐的。

官方推荐列表地址:https://docs.microsoft.com/zh-cn/ef/core/providers/index

  • SqlServer:Microsoft.EntityFrameworkCore.SqlServer
  • MySql:Pomelo.EntityFrameworkCore.MySql
  • Oracle:Oracle.ManagedDataAccess.Core Citms.EntityFrameworkCore.Oracle
  • SqlLite:Microsoft.EntityFrameworkCore.Sqlite

EF相关指令

添加迁移合并版本

Add-Migration v1.0.0 -o Migrations
Add-Migration v1.0.1 -o Migrations

新版指令

进入项目文件夹里面执行(含有.csproj文件的目录)

dotnet ef migrations add v1.0.0
dotnet ef migrations add -p "ConsoleApp.SQLite.csproj"#和上面等效
dotnet ef migrations add --project "ConsoleApp.SQLite.csproj"#和上面等效
dotnet ef migrations add -s "ConsoleApp.SQLite.csproj"#和上面等效
dotnet ef migrations add --startup-project "ConsoleApp.SQLite.csproj"#和上面等效

移除合并

Remove-Migration

新版指令

dotnet ef migrations remove

显示迁移版本列表

dotnet ef migrations list

更新数据库

Update-Database

新版指令

dotnet ef database update

删库指令

Drop-Database

新版指令

dotnet ef database drop

如果上述指令出现不能用的情况,在程序包管理器控制台输入如下命令

Import-Module C:\Users\Administrator\.nuget\packages\microsoft.entityframeworkcore.tools\2.1.0\tools\EntityFrameworkCore.psd1

如果执行上述命令出现 Build failed.

原因是解决方案里面有多种类型的应用程序,只留一种类型,其他的给卸载掉即可,如一个项目里面包含一个控制台项目和webapi项目,就算是设置了控制台为启动项目,但是启动的时候还是会启动Web项目,导致构建失败。

QA

1.执行Add-Migration init报错 Add-Migration : 无法将“Add-Migration”项识别为 cmdlet、函数、脚本文件或可运行程序的名称。请检查名称的拼写,如果包括路径,请确保路径正确,然后再试一次。如何解决?

1、 编译项目。首次在项目中添加EF Core后,这一步必须做,否则都找不到后续要导入的 EntityFrameworkCore.psd1 模块。

2、找到前述文件的位置,使用Import-Module命令导入。我这里为:

Import-Module C:\Users\Administrator\.nuget\packages\microsoft.entityframeworkcore.tools\2.1.0\tools\EntityFrameworkCore.psd1

执行信息如下:

模块“EntityFrameworkCore”中的某些导入命令的名称包含未批准的动词,这些动词可能导致这些命令名不易被发现。若要查找具有未批准的动词的命令,请使用 Verbose 参数再次运行 Import-Module 命令。有关批准的动词列表,请键入 Get-Verb。

之后就可以正常使用命令了。

2.执行 Add-MigrationUpdate-Database出现 build failed 怎么办?

https://stackoverflow.com/questions/44785540/ef-core-add-migration-build-failed

原因是解决方案里面有多种类型的应用程序(项目里面包含Migrations),只留一种类型,其他的给卸载掉即可,如一个项目里面包含一个控制台项目和webapi项目,

就算是设置了控制台为启动项目,但是启动的时候还是会启动Web项目,导致构建失败。

当然,没有失败也不要纠结为啥了,没有失败更好

3.使用sqllite的时候,vs调试提示表不存在怎么办?

要从 Visual Studio 运行此示例,必须手动将工作目录设置为项目的根目录。 如果未设置工作目录,则会引发以下 Microsoft.Data.Sqlite.SqliteExceptionSQLite Error 1: 'no such table: Blogs'

设置工作目录:

  • 在“解决方案资源管理器”中,右键单击该项目,然后选择“属性”。
  • 在左窗格中选择“调试”选项卡。
  • 将工作目录设置为项目目录。
  • 保存更改。

链接:https://docs.microsoft.com/zh-cn/ef/core/get-started/netcore/new-db-sqlite#vs

附加

由于测试使用的是 mysql ,因此还需引入 Pomelo.EntityFrameworkCore.MySql v2.1.2

实际上对于控制台项目,需要引入nuget包,Microsoft.EntityFrameworkCore.Design,此时引入的版本是v2.1.4.

对于Web项目,则需要安装 Microsoft.EntityFrameworkCoreMicrosoft.EntityFrameworkCore.Relational,此时安装的版本都是v2.1.4。

不然执行下面的Entity Framework Core Tools命令会报错,提示缺失上面的依赖库。

学习文档地址:https://gitee.com/dhclly/icedog.script.test/tree/master/doc/dot-net/dot-net-core/entity-framework-core

Entity Framework Core 练习参考的更多相关文章

  1. 创建ASP.NET Core MVC应用程序(3)-基于Entity Framework Core(Code First)创建MySQL数据库表

    创建ASP.NET Core MVC应用程序(3)-基于Entity Framework Core(Code First)创建MySQL数据库表 创建数据模型类(POCO类) 在Models文件夹下添 ...

  2. .Net Core 2.0生态(4):Entity Framework Core 2.0 特性介绍和使用指南

    前言 这是.Net Core 2.0生态生态介绍的最后一篇,EF一直是我喜欢的一个ORM框架,随着版本升级EF也发展到EF6.x,Entity Framework Core是一个支持跨平台的全新版本, ...

  3. Entity Framework Core 2.0 中使用LIKE 操作符

    Entity Framework Core 2.0 中使用LIKE 操作符 不定时更新翻译系列,此系列更新毫无时间规律,文笔菜翻译菜求各位看官老爷们轻喷,如觉得我翻译有问题请挪步原博客地址 本博文翻译 ...

  4. ABP 教程文档 1-1 手把手引进门之 ASP.NET Core & Entity Framework Core(官方教程翻译版 版本3.2.5)

    本文是ABP官方文档翻译版,翻译基于 3.2.5 版本 官方文档分四部分 一. 教程文档 二.ABP 框架 三.zero 模块 四.其他(中文翻译资源) 本篇是第一部分的第一篇. 第一部分分三篇 1- ...

  5. Entity Framework Core 2.0 入门简介

    不多说废话了, 直接切入正题. EF Core支持情况 EF Core的数据库Providers: 此外还即将支持CosmosDB和 Oracle. EFCore 2.0新的东西: 查询: EF.Fu ...

  6. 使用Entity Framework Core访问数据库(DB2篇)

    前言 上一篇讲了一些EF Core访问Oracle的坑.(感兴趣请移步:使用Entity Framework Core访问数据库(Oracle篇)) 这篇主要讲一下关于EF Core访问DB2的一揽子 ...

  7. Entity Framework Core 2.0 入门

    该文章比较基础, 不多说废话了, 直接切入正题. 该文分以下几点: 创建Model和数据库 使用Model与数据库交互 查询和保存关联数据 EF Core支持情况 EF Core的数据库Provide ...

  8. ASP.NET Core 入门教程 8、ASP.NET Core + Entity Framework Core 数据访问入门

    一.前言 1.本教程主要内容 ASP.NET Core MVC 集成 EF Core 介绍&操作步骤 ASP.NET Core MVC 使用 EF Core + Linq to Entity ...

  9. 【EF】Entity Framework Core 2.0 特性介绍和使用指南

    阅读目录 前言 获取和使用 新特性 项目升级和核心API变化 下一步计划 遗憾的地方 回到目录 前言 这是.Net Core 2.0生态生态介绍的最后一篇,EF一直是我喜欢的一个ORM框架,随着版本升 ...

随机推荐

  1. jQuery 源码分析(十六) 事件系统模块 底层方法 详解

    jQuery事件系统并没有将事件监听函数直接绑定到DOM元素上,而是基于数据缓存模块来管理监听函数的,事件模块代码有点多,我把它分为了三个部分:分底层方法.实例方法和便捷方法.ready事件来讲,好理 ...

  2. MECE分析法

      概述 MECE分析法,是麦肯锡的第一个女咨询顾问 Barbara Minto 在金字塔原理中提出的一个很重要的原则. MECE分析法,全称Mutually Exclusive Collective ...

  3. mysqlslap详解--MySQL自带的性能压力测试工具(转)

    本文的参考博客地址为:https://blog.csdn.net/fuzhongfaya/article/details/80943991 和 https://www.cnblogs.com/davy ...

  4. mysql Hash索引和BTree索引区别

    Hash仅支持=.>.>=.<.<=.between.BTree可以支持like模糊查询 索引是帮助mysql获取数据的数据结构.最常见的索引是Btree索引和Hash索引. ...

  5. Jenkins 在 Tomcat 运行访问路径设置

    问题 最近用 Tomcat 搭建了个 Jenkins ,但是访问的时候需要端口加 /jenkins/ 才能进行访问.我们是直接将 Jenkins.war 包放在 webapps下的. 我们想直接通过不 ...

  6. C# - WinFrm应用程序MessageBox自动关闭小实验

    概述 在程序中MessageBox弹出的对话框,用于向用户展示消息,这是一个模式窗口,可阻止应用程序中的其他操作,直到用户将其关闭.但是有时候在自动化程序中,如果弹出对话框,程序将会中断,等待人工的干 ...

  7. C#中 ??、 ?、 ?: 、?.、?[ ] 问号各组合含义

    1. 可空类型修饰符(?) 引用类型可以使用空引用表示一个不存在的值,而值类型通常不能表示为空.例如:string str=null; 是正确的,int i=null; 编译器就会报错.为了使值类型也 ...

  8. Google在情报搜集中的基础技巧

    Google在情报搜集中的基础技巧 作者:王宇阳 时间:2019-06-06 作者笔记 ​ Google Hacking 是指使用特定的高级的google搜索语法,收集渗透测试目标的信息,查找目标的配 ...

  9. Python工具库分享

    漏洞及渗透练习平台: WebGoat漏洞练习平台: https://github.com/WebGoat/WebGoat webgoat-legacy漏洞练习平台: https://github.co ...

  10. Linux中的硬链接和软链接的概念、区别及用法

    概念: 硬链接(hard link): A是B的硬链接(A和B都是文件名),则A的目录项中的inode节点号与B的目录项中的inode节点号相同,即一个inode节点对应两个不同的文件名,两个文件名指 ...