張高興的 Entity Framework Core 即學即用:(一)創建第一個 EF Core 應用

来源:https://www.cnblogs.com/zhanggaoxing/archive/2022/03/22/16040341.html
-Advertisement-
Play Games

.net core IdentityServer4 認證授權 token ...


写在前面

Entity Framework Core (EF Core) 是 .NET 平台流行的对象关系映射(ORM)框架。虽然 .NET 平台中 ORM 框架有很多,比如 Dapper、NHibernate、PetaPoco 等,并且 EF Core 的性能也不是最优的(这是由于 EF 的实体跟踪特性,将其禁用后可以大幅提升性能),但依然吸引到很多后端开发者的使用,原因如下:

  1. EF Core 由 .NET 官方进行开发维护,出现问题解决较为及时,这是很多国产 ORM 框架不具有的优势;
  2. EF Core 和 C# 语法高度绑定,使用 LINQ 不再需要编写复杂的数据库访问代码;
  3. EF Core 支持大部分流行的数据库,切换数据库时只需要更改数据库访问驱动,并不需要更改业务逻辑。
    因此在项目中使用 EF Core 不一定是最优的,但一定不会错。

《张高兴的 Entity Framework Core 即学即用》系列博客将会从实践的角度去介绍 EF Core。由于学习的是数据库访问技术,因此还需要一个数据库供我们实践。将根据如下背景设计一个数据库,本系列博客将基于此数据库进行实践:

新冠肺炎的流行打破了人们原有的正常生活。为了更好地预防和控制疫情,我们决定开发一个病毒检测管理系统,用于记录公民的核酸检测报告。核酸检测在医院进行,所有检测报告将由病毒检测管理系统收集统计。当前有多家医院可以进行核酸检测,未来这些医院的数量也会增加。考虑到病毒的变异以及未来的扩展性,病毒检测管理系统还需要支持存储不同病毒的检测报告。核酸检测的流程由收集患者的基本信息开始,然后是收集样本的类型,最后出具带有医生姓名的核酸检测报告。

《张高兴的 Entity Framework Core 即学即用》系列博客使用 .NET 6 和 EF Core 6 进行编码,保证了技术的时效性。和绝大部分 EF Core 的教程不同,这里并没有选择使用 SQL Server,而是使用 PostgreSQL 数据库。此处并没有否认 SQL Server 是一款优秀的数据库,并且 EF 的很多特性在 SQL Server 上表现更好,可以说 SQL Server 是 EF Core 的最佳实践。但 SQL Server 最致命的问题是闭源并且收费,现在虽然可以跨平台运行,但这个方向仍有很长的路要走。PostgreSQL 开源且免费,甚至可以运行在 ARM 的 Linux 开发板上,性能也要优于 MySQL。PostgreSQL 扩展性高,拥有庞大的插件群,并且还具有一些“领先时代”的功能,可以说是数据库界的 C#。当然本系列博客并没有涉及到数据库的原生操作,如果你不想使用 PostgreSQL,可以直接将 NuGet 包替换成对应数据库的即可,这也是 EF Core 的优势。

《张高兴的 Entity Framework Core 即学即用》系列博客共分为 4 个部分:

  1. 第一部分将从 0 开始创建一个 EF Core 应用,介绍了使用 Database First 的方式以及手工的方式生成实体类,并且尝试查询一张表的数据;
  2. 第二部分介绍了 EF Core 的实体状态以及增删改查等数据库操作;
  3. 第三部分实现了一个 EF Core 的帮助类,以简化数据库的操作和增强扩展性;
  4. 第四部分使用 Razor 引擎实现了一个实体类生成工具。

每一篇博客在介绍功能点时都附带有简单的示例,每一章的最后还附有若干个小练习,希望读者可以借着练习帮助理解,之后根据项目中遇到的问题再学习其他的内容。欢迎批评与指正,有任何的问题都可以通过邮件或者评论的方式与我交流。

张高兴
2022年3月22日


本文将使用 .NET 6 创建一个控制台程序,从 0 开始,学习 EF Core 的使用。通过本文你可以学到:

  1. 使用 Database First 的方式生成实体类;
  2. 熟悉实体类中的 EF Core Attribute;
  3. 查询一张表的数据;
  4. 使用 Docker 拉取镜像。

目录

准备工作

准备工作包含两部分:安装数据库与创建数据库。EF Core 对 PostgreSQL 的版本没有要求,但后续的博客在介绍编写实体类生成工具时要求 12 及以上的版本。

安装 PostgreSQL

直接安装

PostgreSQL 支持在绝大多数操作系统下运行,下载地址:https://www.postgresql.org/download

Windows 下载 exe 安装包,安装时直接点击“下一步”即可,无需额外配置。如果使用 Debian 系列的 Linux 发行版时,直接使用 apt 进行安装,也无需其他操作。其他的操作系统建议根据下载地址中的安装指南进行操作。

使用 Docker 拉取镜像

  1. 拉取 PostgreSQL 镜像:
docker pull postgres
  1. 创建卷,用于持久化数据库数据:
docker volume create pgsql_data
  1. 运行镜像,端口映射为 54321,密码配置为弱密码 @Passw0rd
docker run -d --name pgsql -p 54321:5432 --restart=always -e POSTGRES_PASSWORD='@Passw0rd' -e TZ='Asia/Shanghai' -e ALLOW_IP_RANGE=0.0.0.0/0 -v pgsql_data:/var/lib/postgresql postgres

数据库的表结构

数据库的设计取决于业务的需求,对同样的业务,每个人的设计都有可能不同,数据库的设计并没有标准答案,读者们或许有更好的设计方案,这里给出的表结构仅供参考,只是为了满足教程的需要:


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 外觀模式是什麼 外觀模式是一種結構性設計模式,它能為程式庫、框架或者其他複雜的子系統提供一個統一的高層界面,使子系統更容易使用。外觀模式就是聚合多個介面實現,對外只暴露單個介面。隱藏子系統的複雜性。調用方不關心實現步驟。 為什麼要用外觀模式 當子系統提供的功能很多,而我們子需要多個子系統中很少的幾個 ...
  • 1. Consul 簡介 Consul是 HashiCorp 公司推出的開源工具,用於實現分散式系統的服務發現與配置。與其它分散式服 務註冊與發現的方案,Consul 的方案更“一站式”,內置了服務註冊與發現框 架、分佈一致性協議實 現、健康檢查、Key/Value 存儲、多數據中心方案,不再需要依 ...
  • 1.依賴配置 1.1 pom文件 <properties> <maven.compiler.source>8</maven.compiler.source> <maven.compiler.target>8</maven.compiler.target> <flink.version>1.13.0< ...
  • Hibernate 是一個開放源代碼的對象關係映射框架,它對 JDBC 進行了非常輕量級的對象封裝,它將 POJO 與資料庫表建立映射關係,是一個全自動的 orm 框架 ...
  • Java程式設計基礎之面向對象(下) (補充了上的一些遺漏的知識,同時加入了自己的筆記的ヾ(•ω•`)o) (至於為什麼分P,啊大概是為了自己查筆記方便(?)應該是(〃` 3′〃)) (但是u1s1,學完了面向對象後反而更懵逼,下一步先刷演算法吧,然後Java的學習也跟上,今年爭取考完二級證書(o-ω ...
  • (Java 常見排序演算法) 彙總 序號 排序演算法 平均時間 最好情況 最差情況 穩定度 額外空間 備註 相對時間 1 冒泡演算法 O(n2) O(n) O(n2) 穩定 O(1) n 越小越好 182 ms 2 選擇演算法 O(n2) O(n2) O(n2) 不穩定 O(1) n 越小越好 53 ms ...
  • hello大家好呀,我是小樓~ 今天又帶來一次性能優化的分享,這是我剛進公司時接手的祖傳(壞笑)項目,這個項目在我的文章中屢次被提及,我在它上面做了很多的性能優化,比如《記一次提升18倍的性能優化》這篇文章,比較偏向某個細節的優化,本文更偏向巨集觀上的性能優化,可以說是個老演員了。 背景 為了新朋友能 ...
  • 一、概述 date代表一個特定的時間,精確到毫秒 二、構造方法 方法名說明 public Date() 分配一個Date對象,並初始化,以便它代表被分配的時間,精確到毫秒 public Date(long date) 分配一個Date對象,並將其初始化為表示從標準基準時間起指定的毫秒數 import ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...