中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

c# 使用Entity Framework操作Access數據庫的示例

發布時間:2020-10-07 20:48:38 來源:腳本之家 閱讀:476 作者:Touchumind 欄目:編程語言

Entity Framework是C#開發中最常見的ORM工具。默認Entity Framework只提供支持MSSQL的provider factory。但是開發者開源貢獻了對SQLite、MySql以及Access等的支持。

Entity Framework將概念模型中定義的實體和關系映射到數據源,利用實體框架可以將數據源返回的數據具體化為對象;跟蹤對象所做的更改;并發處理;將對象更改傳播到數據源等。今天我們就一起討論如何利用Entity Framework進行查詢、插入、更新和刪除數據。

EF操作使用步驟:1.創建數據庫,建立表。2.先建一個控制臺程序  3.添加ADO.net實體數據模型(AccountEF.edmx),會生成一個edmx和.cs的文件 ,我們點進.cs 的文件可以看到有(上下文,實體)兩部分.具體代碼如下.
edmx文件,用XML編輯器打開時,我們會看到包括: <!-- SSDL content -->存儲模型

c# 使用Entity Framework操作Access數據庫的示例

JetEntityFrameworkProvider

JetEntityFrameworkProvider為Access數據庫文件兼容Entity Framework提供了相應的Provider。在nuget中直接搜索JetEntityFrameworkProvider即可安裝該工具。雖然大多數操作最終是EntityFramework完成因此不需要什么變化,而在數據庫連接等方面還是有些不同和需要注意的地方。

數據庫連接

官方的資源并不多,只提供了一兩個簡單的操作視頻

其中使用的connectionString為在App.config中或Web.config中預定義的以供DbContext實例化時引用。

<connectionStrings> 
 <add name="DefaultConnection" connectionString="Provider=Microsoft.ACE.OleDb.12.0;Data Source=你的mdb或accdb文件絕對路徑" providerName="JetEntityFrameworkProvider" />
</connectionStrings> 

這樣你在實例化自定義的DbContext子類時直接base("name=DefaultConnection")即可建立數據庫連接。

但是我個人不喜歡在配置文件中寫死配置,我更希望使用base(existingConnection, contextOwnsConnection)這種DbContext構造模式,所以需要先直接生成一個DbConnection,這里具體的就是OleDbConnection而不是SqlConnection了。

按照下面的方式直接使用DbProviderFactory創建連接:

var dbConnectionString = "Provider=Microsoft.ACE.OleDb.12.0;Data source=Access文件絕對路徑;Persist Security Info=False"; 
var conn = DbProviderFactories.GetFactory("JetEntityFrameworkProvider").CreateConnection(); 
conn.ConnectionString = dbConnectionString; 

Code First或DB First

默認地,JetEntityFrameworkProvider只支持code first模式。即你先寫好模型,然后根據模型生成數據庫。

但是我的需求是用EF讀取已存在的Access數據庫文件,即DB First模式,這時使用EF讀取Access數據庫文件會報錯提示數據表已存在。

通過code first模式的測試發現:

JetEntityFrameworkProvider會創建一個名為__MigrationHistory的表,字段如下:

  1. MigrationId - text格式 
  2. ContextKey - memo格式 
  3. Model - OleObject格式 
  4. ProductVersion - text格式 

MigrationId值的例子為201612281720088_InitialCreate

ContextKey應該是自定義的DbContext類的namespace加類名的格式

Model是二進制的數據無法查看

ProductVersion包含了Entity Framework的版本號和JetEntityFrameworkProvider的版本號

因此我嘗試在EF連接之前用普通SQL query方式插入記錄:

var dbConnectionString = "Provider=Microsoft.ACE.OleDb.12.0;Data source=Access文件絕對路徑;Persist Security Info=False"; 
conn = new OleDbConnection(dbConnectionString); 
conn.Open(); 
var exists = conn.GetSchema("Tables", new string[4] { null, null, "__MigrationHistory", "TABLE" }).Rows.Count > 0;

if(!exists) 
 {
   OleDbCommand cmd = new OleDbCommand("CREATE TABLE __MigrationHistory([MigrationId] TEXT, [ContextKey] MEMO, [Model] OleObject, [ProductVersion] TEXT)", conn);
   cmd.ExecuteNonQuery();

   cmd = new OleDbCommand("INSERT INTO __MigrationHistory(MigrationId, ContextKey, ProductVersion) VALUES('" + DateTime.Now.ToString("yyyyMMddHHmmssfff") + "', '" + typeof(ATOrionContext).Namespace + ".ATOrionContext', '6.1.3-40302')", conn);
   cmd.ExecuteNonQuery();

 }

執行如上操作后確實能夠利用EF連接已存在模型對應數據表的Access數據庫文件了,但是執行查詢操作仍然會報錯buffer is null

經過Debug發現此buffer指的就是插入記錄的Model字段,我們插入時沒有提供值,因為它是一個二進制數據,內容生成方式未知。

嘗試注釋掉插入記錄的操作,只添加__MigrationHistory表,而結果也令人興奮,可以通過模型驗證并且能夠使用EF進行DB First模式的數據開發模式了。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巴南区| 香河县| 黔西县| 蒙城县| 东丰县| 木兰县| 博湖县| 永胜县| 利津县| 唐山市| 广宁县| 中山市| 上饶县| 越西县| 太原市| 石台县| 揭西县| 海丰县| 广元市| 扎囊县| 石屏县| 泸西县| 南阳市| 沁阳市| 齐齐哈尔市| 克什克腾旗| 友谊县| 扎鲁特旗| 梅河口市| 高碑店市| 商洛市| 稻城县| 商丘市| 中西区| 米脂县| 临沂市| 城步| 西平县| 贵定县| 通许县| 永登县|