首页
/ 探索Entity Framework Core的无限可能:《实体框架Core实战》开源代码库

探索Entity Framework Core的无限可能:《实体框架Core实战》开源代码库

2024-05-20 18:41:16作者:翟萌耘Ralph

欢迎来到与《实体框架Core实战》一书配套的Git仓库——EfCoreInAction。这本书由Manning出版社出版,详细介绍了如何在.NET Core应用程序中利用Entity Framework Core(EF Core)开发数据库访问代码。

这个Git仓库包含了书中所有的代码示例,以及一个在书中逐步构建和优化的在线图书售卖网站。所有代码均基于微软的开源库——EF Core进行开发。

请注意:代码基于.NET Core 2.0,部分分支已升级到.NET Core 2.1。

开发环境要求

要运行这些代码,您需要:

  1. 安装.NET Core 2.0 SDK,前往官方网站选择适合您的系统的版本。
  2. 建议使用Visual Studio 2017 15.3或更高版本,或者Visual Studio Code。因为代码设计为在这两个环境中都能正常工作。

代码结构一览

本仓库采取了“章节分支”的方式管理代码,这意味着在主分支上找不到代码。只需点击Branches,即可查看所有创建的分支。

每个部分的分支结构如下:

第一部分:入门

                                        Ch5Migrate
                                          /
master    Ch1    Ch2 --> Ch3 --> Ch4 --> Ch5 -->

第二部分:深入理解Entity Framework

(ch5) --> Ch6 --> Ch7 --> Ch8 --> Ch9

第三部分:在真实世界的应用程序中使用Entity Framework

                                           Ch13-Part3
                                              /
                                        Ch13-Part2    Ch14MySql
                                            /         /
(ch9) --> Ch10 --> Ch11 --> Ch12 --> Ch13-Part1 --> Ch14  --> (Ch15) Note1

注:第15章关于单元测试的内容有自己的Git仓库,地址是:https://github.com/JonPSmith/EfCore.TestSupport,并提供了一个名为EfCore.TestSupport的NuGet包。

此外,为了对比EF Core 2.0和2.1的性能,还特别创建了几个针对.NET Core 2.1的分支,如Chapter05-NetCore21等。对于EF Core 3的支持,也有相应的分支,如Chapter01-NetCore3等。

实时示例书籍销售网站

您可以访问efcoreinaction.com以查看在线版本的图书销售站点。虽然无法在此处编辑数据,但当您将Git仓库克隆到本地并运行示例应用时,就可以进行编辑操作。在“日志”导航栏下,可以看到实现最后一条命令所使用的SQL代码。

数据库命名约定

由于不同分支下的数据库结构可能会变化,因此我们采用了一种从文件中读取分支名来构造数据库名称的方法。另外,由于xUnit单元测试会并行执行,所以不能共用一个数据库,以免相互影响。详细的解释在第11章中有所描述,不过这会导致运行单元测试时产生大量数据库。如果您对此感到困扰,可以运行测试/UnitCommands/DeleteAllUnitTestDatabases中的单元测试来删除所有测试数据库。

许可协议

该项目遵循MIT许可

其他资源

您可以在Twitter上关注我[@thereformedprog],也可以访问我的博客http://www.thereformedprogrammer.net/,那里有更多关于EF 6.x和一些EF Core的文章。

快乐编码!

热门项目推荐
相关项目推荐

项目优选

收起
Python-100-DaysPython-100-Days
Python - 100天从新手到大师
Python
576
107
Ffit-framework
面向全场景的 Java 企业级插件化编程框架,支持聚散部署和共享内存,以一切皆可替换为核心理念,旨在为用户提供一种灵活的服务开发范式。
Java
111
13
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
285
74
RuoYi-Cloud-Vue3RuoYi-Cloud-Vue3
🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
44
29
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
204
50
LangBotLangBot
😎丰富生态、🧩支持扩展、🦄多模态 - 大模型原生即时通信机器人平台 | 适配 QQ / 微信(企业微信、个人微信)/ 飞书 / 钉钉 / Discord / Telegram 等消息平台 | 支持 OpenAI GPT、ChatGPT、DeepSeek、Dify、Claude、Gemini、Ollama、LM Studio、SiliconFlow、Qwen、Moonshot、ChatGLM 等 LLM 的机器人 / Agent | LLM-based instant messaging bots platform, supports Discord, Telegram, WeChat, Lark, DingTalk, QQ, OpenAI ChatGPT, DeepSeek
Python
7
1
RGF_CJRGF_CJ
RGF是Windows系统下的通用渲染框架,其基于Direct3D、Direct2D、DXGI、DirectWrite、WIC、GDI、GDIplus等技术开发。RGF仓颉版(后续简称"RGF")基于RGF(C/C++版)封装优化而来。RGF为开发者提供轻量化、安全、高性能以及高度一致性的2D渲染能力,并且提供对接Direct3D的相关接口,以满足开发者对3D画面渲染的需求。
Cangjie
11
0
omega-aiomega-ai
Omega-AI:基于java打造的深度学习框架,帮助你快速搭建神经网络,实现模型推理与训练,引擎支持自动求导,多线程与GPU运算,GPU支持CUDA,CUDNN。
Java
11
2
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
59
47
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
900
0