《Entity Framework 6 Recipes》翻譯系列(2) -----第一章 開始使用實體框架之使用

来源:http://www.cnblogs.com/wufei999/archive/2017/04/28/6782167.html
-Advertisement-
Play Games

Visual Studio 我們在Windows平臺上開發應用程式使用的工具主要是Visual Studio.這個集成開發環境已經演化了很多年,從一個簡單的C++編輯器和編譯器到一個高度集成、支持軟體開發整個生命周期的多語言環境。 Visual Studio以及它發佈的工具和服務提供了:設計、開發、 ...


Visual Studio

  我們在Windows平臺上開發應用程式使用的工具主要是Visual Studio.這個集成開發環境已經演化了很多年,從一個簡單的C++編輯器和編譯器到一個高度集成、支持軟體開發整個生命周期的多語言環境。 Visual Studio以及它發佈的工具和服務提供了:設計、開發、單元測試、調試、軟體配置和管理、構建管理和持續集成等等。很少有開發人員因為還沒有使用它而擔心(註:作者應該是表達不用擔心VS的能力),Visual Studio是一個完整的工具集。Visual Studio在開發應用實體框架的應用程式中起著至關重要的作用。

  Visual Studio為實體框架模型提供了一個集成的設計器,使用它提供的工具,你可以從頭創建或者從已存在的資料庫創建模型。當然,你可以選擇不使用設計器,純手工來創建實體類型和配置。

  多數情況下,我們擁有一個已經存在的應用和資料庫,VisualStudio為我們提供了工具,它可以幫我們把資料庫中的表和關係導入到實體框架模型。這非常適合我們,因為很少有人會奢侈選擇開發一個嶄新的應用程式。多數情況下我們是維護、擴展、改進一個已存在的代碼和資料庫。

  你可以在計器中創建一個空模型,然後從頭開始增加實體類型、類型間的關聯以及承繼體繫到設計器中。 當你創建好模型後,你可以右鍵設計器,然後從菜單中選擇從模型創建資料庫。

  如果你的項目團隊是以代碼為中心的,你可以在不使用設計器的情況下手工創建一系列的領域類、它們之間的關係、上下文對象,然後把這些類和實體框架引擎關聯起來。

  一旦創建好模型,改動是經常發生的,因為這對軟體開發來說是再自然不過的事。Visual Studio提供了工具幫我們從資料庫更新我們的模型,這會使模型和資料庫同步。另外,實體框架開發團隊還為我們提供了一個名為代碼優先遷移(Code First Migrations)工具,它能讓資料庫保持你模型中最新的修改。

 1-2 使用實體框架

  實體框架緊緊地和Visual Studio集成在一起,為了在你的應用程式中使用實體框架,我們增加一個ADO.NET實體數據框架到你的項目。方法如下:右鍵你的項目,然後選擇 ➤New Item(新建項)。在彈出的對話框中(如圖1-4),選擇Data(數據)模板下邊的ADO.NET Entity Date Model(實體數據模型)模板。然後單擊Add(增加)打開數據模型創建導向。

圖1-4 向項目中添加實體數據模型

  在第一頁嚮導中有兩個選項: start with an existing database (從一個已存的數據創建);start with an empty model(創建一個空模型)。(前者的選項標簽實際為“Generate from database”),如圖1-5。

圖1-5實體數據模型嚮導給出從已存在的資料庫創建和創建空模型選擇

   從已存在資料庫創建模型是資料庫優先(Database-First)方案。從你選擇的資料庫的表、視圖、存儲過程,嚮導會為創建好模型和用於編碼的實體類。立馬得到的好處就是,你可以在編碼中使用實體框架從資料庫中的表和列映射到模型中的強類型的實體類。如果資料庫中的表間是有關係的,他們會被建模成關聯。如果你有一個已經存在的資料庫,這是為你的應用創建實體數據模型的一種方式。然而,如果你喜歡使用代碼優先(Code-First)方案從一個已存在的資料庫創建模型,不用擔心,實體框架開發團隊已經創建了強有力的工具集(The Entity Framework Power Tools),它通過逆向工程,從一個存在的資料庫創建領域實體類,就像你手工敲出來的一樣。

   如果你開發一個嶄新的應用,沒有已存在的資料庫,你同樣也可以選擇實體框架設計器。先創建一個空的模型,然後通過右鍵創建實體類型、關聯、繼承。也可以從工具箱中拖拽到設計器中創建它們。一旦建模完成,你就可以右鍵設計器選擇 Generate Database from Model(從模型創建資料庫)菜單項。它會產生一個用來創建資料庫表、關係的腳本。

  你也可以在Visual Studio中手工創建每一個實體類,然後在DbContext上下文對象中註冊它們,這樣就能和實體框架服務相銜接。實體框架映射這些實體類到底層的資料庫,併在運行時,於記憶體中自動創建一個模型。

  模型優先(Model-First)或者資料庫優先(Database-First),使用實體框架設計器建模。其中的關鍵點如圖1-6所示。在這個模型中,Customer 和 Order擁有一對多關聯,每一個Customer可能有多個Orders,但是每個Order只能關聯一個Customer.映射詳細信息視窗顯示一個實體類型的Customer映射到底層資料庫中的Customer表。該視窗同時也顯示了,Customer表中的列映射到實體類型Customer中的標量屬性(Scalar Proerties).記住,在實體框架中,你能使用數據註解或者代碼優先(Code-First)中的API特性來創建同樣的映射。

圖1-6設計器建模中的關鍵點

  當然,設計器建模中的關鍵點遠不止圖1-6所呈現的,本書將覆蓋設計器建模的方方面面。某些情況下,會超出設計器的能力範圍,本書將展示通過修改底層的.edmx文件來處理這類情況。該文件包含了完整的模型定義,包含概念層、存儲邏輯層、映射層。

  所以,無論我們在實體框架中使用資料庫優先(Database-First)、模型優先(Model-First)、代碼優先(Code-First),我最終都需要使用一個模型。我們獲得了較高的生產率,因為在編碼時,我們可以像使用應用程式中別的普通對象一樣使用模型(實體類),如圖1-6所示,在許多情況,你可以像使用應用程式中別的普通對象一樣使用Customer和Order對象。

  如果你想插入一個新的customer 和 order到資料庫中,你可以創建Customer和Order類型的一個實例,設置它們的屬性。然後將其添加到記憶體中代表模型的上下文對象中。最後調用Savechanges()方法保存。所需要的SQL語句將被自動生成併發送到資料庫中實現插入一行。獲取資料庫中的customers和orders,你可以根據模型中的實體類型和關聯,使用LINQ或者實體SQL創建一個查詢來實現。

  貫穿本書的技巧將一步一步地向你展示,如何在幾乎所有能想到的資料庫上建模的場景;如何通過模型實現查詢、插入、更新和刪除。以及在各種各樣的應用程式中如何運用實體框架。

  第一章,到此結束。如果你覺得不錯,就請點擊右下邊的推薦,以便與更多的人分享。

 

 

實體框架交流QQ群:  458326058,歡迎有興趣的朋友加入一起交流

謝謝大家的持續關註,我的博客地址:http://www.cnblogs.com/VolcanoCloud/

 

參考頁面:http://qingqingquege.cnblogs.com/p/5933752.html


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

-Advertisement-
Play Games
更多相關文章
  • 1 系統調用的作用 系統調用是操作系統提供給用戶(應用程式)的一組介面,每個系統調用都有一個對應的系統調用函數來完成相應的工作。用戶通過這個介面向操作系統申請服務,如訪問硬體,管理進程等等。 應用程式和文件系統的介面是系統調用。 我們經常看到的比如fork、open、write 等等函數實際上並不是 ...
  • 首先,來查看下系統當前都開放了什麼埠,怎樣查看呢?調出cmd命令行程式,輸入命令”netstat -na“,可以看到。 接著,可以發現當前系統開放了135、445以及5357埠,而且從狀態看都處於監聽狀態”Listening“。 然後,確認自己的系統已經開放了445埠之後,我們開始著手關閉這個 ...
  • 1 安裝tftp-server sudo apt-get install tftpd-hpa sudo apt-get install tftp-hpa(如果不需要客戶端可以不安裝) 2 配置tftp伺服器 第1步: 修改/etc/default/tftpd-hpa配置文件。 將/etc/defau ...
  • 最近有在學習會話共用的配置,其中一種呢是 nginx+redis+tomcat 的會話共用配置,在記錄此會話共用配置之前呢先記錄下redis等的安裝。這篇先簡單記錄下redis的安裝,是其中一種方式,其他的後續會進行補充或單獨記錄。 準備: 解壓tcl.tar.gz,並編譯安裝: 解壓redis.t ...
  • 以前簡單介紹過web api 的設計,但是還是有很多朋友問我,如何合理的設計和實現web api。比如,介面安全,異常處理,統一數據返回等問題。所以有必要系統的總結總結 web api 的設計和實現。由於前面已經介紹過web api 的參數和返回格式的設計,《Web API系列(一)設計經驗與總結》 ...
  • 一、前言 我們在優化Web服務的時候,對於靜態的資源文件,通常都是通過客戶端緩存、伺服器緩存、CDN緩存,這三種方式來緩解客戶端對於Web伺服器的連接請求壓力的。 本文指在這三個方面,在ASP.NET Core中靜態文件的實現過程和使用方法進行闡述。當然也可以考慮使用反向代理的方式(例如IIS或Ng ...
  • 這裡的“私闖sys.databases”是指Entity Framework預設發起的查詢:SELECT Count(*) FROM sys.databases WHERE [name]=N'資料庫名' 註:本文針對的是Entity Framework Code First場景,Entity Fra ...
  • 最近做一個指紋採集和比對的功能,因為公司整個項目是WEB類型的,所以指紋採集的模塊要嵌套在網頁中,那隻有用ActiveX了,以下是一些操作及效果,做個筆記! 新建用戶控制項,編寫CS代碼,如下: ? 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...