c# 使用Entity Framework操作Access數(shù)據(jù)庫(kù)的示例
Entity Framework是C#開(kāi)發(fā)中最常見(jiàn)的ORM工具。默認(rèn)Entity Framework只提供支持MSSQL的provider factory。但是開(kāi)發(fā)者開(kāi)源貢獻(xiàn)了對(duì)SQLite、MySql以及Access等的支持。
Entity Framework將概念模型中定義的實(shí)體和關(guān)系映射到數(shù)據(jù)源,利用實(shí)體框架可以將數(shù)據(jù)源返回的數(shù)據(jù)具體化為對(duì)象;跟蹤對(duì)象所做的更改;并發(fā)處理;將對(duì)象更改傳播到數(shù)據(jù)源等。今天我們就一起討論如何利用Entity Framework進(jìn)行查詢、插入、更新和刪除數(shù)據(jù)。
EF操作使用步驟:1.創(chuàng)建數(shù)據(jù)庫(kù),建立表。2.先建一個(gè)控制臺(tái)程序 3.添加ADO.net實(shí)體數(shù)據(jù)模型(AccountEF.edmx),會(huì)生成一個(gè)edmx和.cs的文件 ,我們點(diǎn)進(jìn).cs 的文件可以看到有(上下文,實(shí)體)兩部分.具體代碼如下.
edmx文件,用XML編輯器打開(kāi)時(shí),我們會(huì)看到包括: <!-- SSDL content -->存儲(chǔ)模型
JetEntityFrameworkProvider
JetEntityFrameworkProvider為Access數(shù)據(jù)庫(kù)文件兼容Entity Framework提供了相應(yīng)的Provider。在nuget中直接搜索JetEntityFrameworkProvider即可安裝該工具。雖然大多數(shù)操作最終是EntityFramework完成因此不需要什么變化,而在數(shù)據(jù)庫(kù)連接等方面還是有些不同和需要注意的地方。
數(shù)據(jù)庫(kù)連接
官方的資源并不多,只提供了一兩個(gè)簡(jiǎn)單的操作視頻
其中使用的connectionString為在App.config中或Web.config中預(yù)定義的以供DbContext實(shí)例化時(shí)引用。
<connectionStrings> <add name="DefaultConnection" connectionString="Provider=Microsoft.ACE.OleDb.12.0;Data Source=你的mdb或accdb文件絕對(duì)路徑" providerName="JetEntityFrameworkProvider" /> </connectionStrings>
這樣你在實(shí)例化自定義的DbContext子類時(shí)直接base("name=DefaultConnection")即可建立數(shù)據(jù)庫(kù)連接。
但是我個(gè)人不喜歡在配置文件中寫死配置,我更希望使用base(existingConnection, contextOwnsConnection)這種DbContext構(gòu)造模式,所以需要先直接生成一個(gè)DbConnection,這里具體的就是OleDbConnection而不是SqlConnection了。
按照下面的方式直接使用DbProviderFactory創(chuàng)建連接:
var dbConnectionString = "Provider=Microsoft.ACE.OleDb.12.0;Data source=Access文件絕對(duì)路徑;Persist Security Info=False"; var conn = DbProviderFactories.GetFactory("JetEntityFrameworkProvider").CreateConnection(); conn.ConnectionString = dbConnectionString;
Code First或DB First
默認(rèn)地,JetEntityFrameworkProvider只支持code first模式。即你先寫好模型,然后根據(jù)模型生成數(shù)據(jù)庫(kù)。
但是我的需求是用EF讀取已存在的Access數(shù)據(jù)庫(kù)文件,即DB First模式,這時(shí)使用EF讀取Access數(shù)據(jù)庫(kù)文件會(huì)報(bào)錯(cuò)提示數(shù)據(jù)表已存在。
通過(guò)code first模式的測(cè)試發(fā)現(xiàn):
JetEntityFrameworkProvider會(huì)創(chuàng)建一個(gè)名為_(kāi)_MigrationHistory的表,字段如下:
- MigrationId - text格式
- ContextKey - memo格式
- Model - OleObject格式
- ProductVersion - text格式
MigrationId值的例子為201612281720088_InitialCreate
ContextKey應(yīng)該是自定義的DbContext類的namespace加類名的格式
Model是二進(jìn)制的數(shù)據(jù)無(wú)法查看
ProductVersion包含了Entity Framework的版本號(hào)和JetEntityFrameworkProvider的版本號(hào)
因此我嘗試在EF連接之前用普通SQL query方式插入記錄:
var dbConnectionString = "Provider=Microsoft.ACE.OleDb.12.0;Data source=Access文件絕對(duì)路徑;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(); }
執(zhí)行如上操作后確實(shí)能夠利用EF連接已存在模型對(duì)應(yīng)數(shù)據(jù)表的Access數(shù)據(jù)庫(kù)文件了,但是執(zhí)行查詢操作仍然會(huì)報(bào)錯(cuò)buffer is null
經(jīng)過(guò)Debug發(fā)現(xiàn)此buffer指的就是插入記錄的Model字段,我們插入時(shí)沒(méi)有提供值,因?yàn)樗且粋€(gè)二進(jìn)制數(shù)據(jù),內(nèi)容生成方式未知。
嘗試注釋掉插入記錄的操作,只添加__MigrationHistory表,而結(jié)果也令人興奮,可以通過(guò)模型驗(yàn)證并且能夠使用EF進(jìn)行DB First模式的數(shù)據(jù)開(kāi)發(fā)模式了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持我們。
上一篇:判斷一個(gè)整數(shù)是否是2的N次冪實(shí)現(xiàn)方法
欄 目:C#教程
下一篇:C#基于簡(jiǎn)單工廠模式實(shí)現(xiàn)的計(jì)算器功能示例
本文標(biāo)題:c# 使用Entity Framework操作Access數(shù)據(jù)庫(kù)的示例
本文地址:http://mengdiqiu.com.cn/a1/C_jiaocheng/5405.html
您可能感興趣的文章
- 01-10C#使用Dispose模式實(shí)現(xiàn)手動(dòng)對(duì)資源的釋放
- 01-10C#3.0使用EventLog類寫Windows事件日志的方法
- 01-10C#使用windows服務(wù)開(kāi)啟應(yīng)用程序的方法
- 01-10c# ArrayList的使用方法小總結(jié)
- 01-10C#使用ADO.Net部件來(lái)訪問(wèn)Access數(shù)據(jù)庫(kù)的方法
- 01-10C#使用Mutex簡(jiǎn)單實(shí)現(xiàn)程序單實(shí)例運(yùn)行的方法
- 01-10使用Nopcommerce為商城添加滿XX減XX優(yōu)惠券功能
- 01-10C#修改IIS站點(diǎn)framework版本號(hào)的方法
- 01-10C#中yield用法使用說(shuō)明
- 01-10C#編程和Visual Studio使用技巧(下)


閱讀排行
- 1C語(yǔ)言 while語(yǔ)句的用法詳解
- 2java 實(shí)現(xiàn)簡(jiǎn)單圣誕樹(shù)的示例代碼(圣誕
- 3利用C語(yǔ)言實(shí)現(xiàn)“百馬百擔(dān)”問(wèn)題方法
- 4C語(yǔ)言中計(jì)算正弦的相關(guān)函數(shù)總結(jié)
- 5c語(yǔ)言計(jì)算三角形面積代碼
- 6什么是 WSH(腳本宿主)的詳細(xì)解釋
- 7C++ 中隨機(jī)函數(shù)random函數(shù)的使用方法
- 8正則表達(dá)式匹配各種特殊字符
- 9C語(yǔ)言十進(jìn)制轉(zhuǎn)二進(jìn)制代碼實(shí)例
- 10C語(yǔ)言查找數(shù)組里數(shù)字重復(fù)次數(shù)的方法
本欄相關(guān)
- 01-10C#通過(guò)反射獲取當(dāng)前工程中所有窗體并
- 01-10關(guān)于ASP網(wǎng)頁(yè)無(wú)法打開(kāi)的解決方案
- 01-10WinForm限制窗體不能移到屏幕外的方法
- 01-10WinForm繪制圓角的方法
- 01-10C#實(shí)現(xiàn)txt定位指定行完整實(shí)例
- 01-10WinForm實(shí)現(xiàn)仿視頻播放器左下角滾動(dòng)新
- 01-10C#停止線程的方法
- 01-10C#實(shí)現(xiàn)清空回收站的方法
- 01-10C#通過(guò)重寫Panel改變邊框顏色與寬度的
- 01-10C#實(shí)現(xiàn)讀取注冊(cè)表監(jiān)控當(dāng)前操作系統(tǒng)已
隨機(jī)閱讀
- 04-02jquery與jsp,用jquery
- 08-05dedecms(織夢(mèng))副欄目數(shù)量限制代碼修改
- 01-10delphi制作wav文件的方法
- 01-11Mac OSX 打開(kāi)原生自帶讀寫NTFS功能(圖文
- 01-10使用C語(yǔ)言求解撲克牌的順子及n個(gè)骰子
- 08-05DEDE織夢(mèng)data目錄下的sessions文件夾有什
- 01-10SublimeText編譯C開(kāi)發(fā)環(huán)境設(shè)置
- 01-10C#中split用法實(shí)例總結(jié)
- 08-05織夢(mèng)dedecms什么時(shí)候用欄目交叉功能?
- 01-11ajax實(shí)現(xiàn)頁(yè)面的局部加載