EF啟程--概念理解(資料庫連接)

来源:https://www.cnblogs.com/zhao-y/archive/2019/05/22/10906099.html
-Advertisement-
Play Games

簡介:Entity Framework 是一種支持 .NET 開發人員使用 .NET 對象處理資料庫的對象關係映射程式 (O/RM)。 它不要求提供開發人員通常需要編寫的大部分數據訪問代碼。 其中有EFCore和EF6(最新版本)。都是虛的詳細的看管方文檔有詳細說明:https://docs.mic ...


簡介:Entity Framework 是一種支持 .NET 開發人員使用 .NET 對象處理資料庫的對象關係映射程式 (O/RM)。 它不要求提供開發人員通常需要編寫的大部分數據訪問代碼。

其中有EFCore和EF6(最新版本)。都是虛的詳細的看管方文檔有詳細說明:https://docs.microsoft.com/zh-cn/ef/#pivot=entityfmwk&panel=entityfmwk1

下麵分開介紹二者之間,的開始準備步驟。

1.Entity Framework (EF) Core 是輕量化、可擴展、開源和跨平臺版的常用 Entity Framework 數據訪問技術

EF Core 是一個 .NET Standard 2.0 庫,需要項目 .NET Standard 2.0 支持。

 

使用 工具- NuGet-程式包管理器-執行命令導入所需NuGet --Visual Studio NuGet 包管理器控制台)

(1)用的 SQL Server,使用以下 .NET Core CLI 命令來安裝或更新 EF Core SQL Server 提供程式:

Install-Package Microsoft.EntityFrameworkCore.SqlServer

(2)連接mysql資料庫

Install-Package MySql.Data.EntityFrameworkCore
或者使用第三方:
Install-Package Pomelo.EntityFrameworkCore.MySql

2.資料庫連接

(1)配置文件,進行配置

{
  "Logging": {
    "LogLevel": {
      "Default": "Warning"
    }
  },
  "DBSetting": {
    "ConnectString": "server=127.0.0.1;port=3306;UserId=test;password=root;Database=ding"
  },//mysql本地連接
  "AllowedHosts": "*"
}
//UseSqlServer連接:Server=(localdb)\mssqllocaldb;Database=Blogging;Integrated Security=True

(2)連接代碼

using Microsoft.EntityFrameworkCore;
using Microsoft.Extensions.Configuration;
namespace DingService.Models
{
public partial class DingAuthorizeDb : DbContext
{
public DingAuthorizeDb()
{
}

public DingAuthorizeDb(DbContextOptions<DingAuthorizeDb> options) : base(options) {


}
public virtual DbSet<UsrInfo> usrInfo { set; get; }
protected override void OnConfiguring(DbContextOptionsBuilder optionsBuilder)
{
if (!optionsBuilder.IsConfigured)
{
//載入appsetting.json
IConfiguration configuration = new ConfigurationBuilder()
.SetBasePath(Directory.GetCurrentDirectory())
.AddJsonFile("appsettings.json").Build();

string connectionString = configuration["DBSetting:ConnectString"];
#region nysql 資料庫連接 由於本項目中使用的本地mysql進行項目調試。sql server暫時註釋
optionsBuilder.UseMySQL(connectionString);
#endregion
#region nysql 資料庫連接
// optionsBuilder.UseSqlServer(connectionString);
#endregion
base.OnConfiguring(optionsBuilder);
}
}

}
}

 以上供自己備忘:

下麵簡述自己在從0中遇到的問題以及補足

1.首先要分清自己想要做什麼。開發過程中一直用optionsBuilder.UseSqlServer方法連接我的mysql資料庫(沒有註意專有方法)。在連接資料庫的時候總會出現

A network-related or instance-specific error occurred while establishing a connection to SQL Server

大意就是無法連接sql server資料庫, 現在看就已經很明顯了。因為我沒用(額--好像不對。是沒用sql server資料庫 還用optionsBuilder.UseSqlServer方法)撒幣了

沒有區分mysql與sql server區別

現在簡單補充下區別:

  <1>.首先部分語法存在差別(基本語法相同)可參考:https://blog.csdn.net/qq_40985788/article/details/82717462(引用,謝謝)

  <2>.剩下的就是一些歷史背景原因了。(可以百度參考)

3.再記錄下資料庫連接成功後的倆異常吧

 <1>An error occurred while updating the entries. See the inner exception for details 查看model數據類型是否和資料庫的數據類型是否一致

 <2>The entity type 'UsrInfo' requires a primary key to be defined.  解決方案: 查看model數據中是否沒有定義[key]主鍵

 

  

 

入門先記錄這麼多吧,後續繼續學習。再更新增、刪、改、查。挖掘的不深,莫怪。有個好心情很重要,希望有好見解。共同成長。

 


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

-Advertisement-
Play Games
更多相關文章
  • 問題一:如何不讓WebBrowser中彈出“安全警告” 當鏈接https網址時,IE會自動彈出上圖中的視窗。 關閉視窗的具體思路如下: 使用WebBrowser載入中/載入完畢後觸發的事件處理程式,在處理程式中查找“安全警告”視窗,併在找到視窗後自動點擊“是”或“否”來關閉視窗。 具體方法是: 1. ...
  • 什麼是 I2C 匯流排 I2C 匯流排(Inter Integrated Circuit Bus)是設備與設備間通信方式的一種。它是一種串列通信匯流排,由飛利浦公司在1980年代為了讓主板、嵌入式系統或手機用以連接低速周邊設備而發展 "[1]" 。I2C 匯流排包含兩根信號線,一根為信號線 SDA ,另一根 ...
  • Ocelot(三) 服務發現 作者:markjiang7m2 原文地址: 源碼地址:https://gitee.com/Sevenm2/OcelotDemo 本文是我關於Ocelot系列文章的第三篇,主要是給大家介紹Ocelot的另一功能。與其說是給大家介紹,不如說是我們一起來共同探討,因為我也是在 ...
  • 自己的意識中一個好的可持續性項目應具備一些特點: 項目在能夠實現業務需要的前提下越簡單越好,特別是項目前期不過度設計,慢慢迭代重構; 有一套完善的服務端數據驗證機制(非前端類似JS校驗),可以相信入庫的數據就是符合邏輯的,並且要易於維護; 可以做但並非必須的分散式部署; 可實現多版本資料庫的支持並且 ...
  • 我們的 API 之前是一個單體應用,各個模塊的服務是通過 Assembly 集成在一起,最後部署在一個 web server 下的。 我們已經在拆分服務並且在 [Ocelot](https://github.com/ThreeMammals/Ocelot) 的基礎上封裝了我們自己的網關,但是服務還... ...
  • 1、首先新建一個類庫,然後通過NuGet安裝下麵三個包 2、然後在程式包管理器控制臺中運行以下代碼(ps:記得預設項目選擇剛纔新建的項目,同時設置為啟動項) ps:如果資料庫表變動,需要重新生成model,在上面語句中末尾加上 -Force 即可覆蓋model 3、如果你已經有資料庫表的話,接下系統 ...
  • 1、安裝NuGet包 2、根據現有資料庫執行逆向工程代碼生成實體類 3、依賴註入 4、控制器構造方法初始化 ...
  • 現有項目是利用C#的socket與PLC進行實時通訊,PLC有兩種通訊模式——常規採集&高頻採集。 其中常規採集大概在10ms左右發送一次數據,高頻採集大概在2ms左右發送一次數據。 現有代碼框架:在與PLC進行連接時,通過建立委托並創建線程的方式,來迴圈讀取數據 只要連接PLC成功後,會一直在後臺 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...