佳木斯湛栽影视文化发展公司

主頁 > 知識庫 > 使用Entity Framework(4.3.1版本)遇到的問題整理

使用Entity Framework(4.3.1版本)遇到的問題整理

熱門標(biāo)簽:服務(wù)器配置 Mysql連接數(shù)設(shè)置 Linux服務(wù)器 團(tuán)購網(wǎng)站 科大訊飛語音識別系統(tǒng) 電子圍欄 阿里云 銀行業(yè)務(wù)
在這里記錄一下之前使用Entity Framework(4.3.1版本)遇到的問題。
更新沒有設(shè)置主鍵的表
在默認(rèn)情況下,EF不能對一個沒有主鍵的表進(jìn)行更新、插入和刪除的動作。用xml方式查看edmx文件,可以在SSDL中可以看到如下xml片斷(我定義了一個沒有主鍵的表tb_WithoutKey)。
復(fù)制代碼 代碼如下:

EntitySet Name="tb_WithoutKey" EntityType="TransferModel.Store.tb_WithoutKey" store:Type="Tables" store:Schema="dbo" store:Name="tb_WithoutKey">
DefiningQuery>
SELECT
[tb_WithoutKey].[ID] AS [ID],
[tb_WithoutKey].[Name] AS [Name]
FROM [dbo].[tb_WithoutKey] AS [tb_WithoutKey]
/DefiningQuery>
/EntitySet>

我再加入一個有主鍵的表進(jìn)行對比,同樣的在SSDL中,可以看到有主鍵的表的定義如下。
復(fù)制代碼 代碼如下:

EntitySet Name="tb_WithKey" EntityType="TransferModel.Store.tb_WithKey" store:Type="Tables" Schema="dbo" />

我們把沒有主鍵的EntitySet>照著上面這個節(jié)點進(jìn)行更改:刪除DefiningQuery>節(jié)點,將store:Schema=”dbo”更改為Schema=”dbo”。這樣我們就可以對之前沒有設(shè)置主鍵的表進(jìn)行更新、刪除以及插入操作了。
無主鍵的表SSDL定義其實更像是視圖,我有一點不明的是store:這個命名空間的作用是什么,為什么只是刪除DefiningQuery>不行,還需要將Schema屬性的store命名空間刪除才可以。以上都是我還不明白的地方,只是作為一個解決方案,它確實簡單可行。
更改Code-First的默認(rèn)連接
我們知道使用Code-First的時候我們甚至可以不用寫連接字符串,但是這個默認(rèn)的連接只識別本機(jī)的SQL Express版數(shù)據(jù)庫,如果你是使用其它數(shù)據(jù)庫甚至就是Sql Server非Express版,都不行。
在不提供任何連接數(shù)據(jù)庫信息的情況下,EF會創(chuàng)建一個默認(rèn)的DefaultConnectionFactory,這個默認(rèn)的連接工廠使用的就是SqlConnectionFactory,然后我們可以通過reflector看到它的構(gòu)造函數(shù)如下。
public SqlConnectionFactory()
{
this._baseConnectionString = @"Data Source=.\SQLEXPRESS; Integrated Security=True; MultipleActiveResultSets=True";
}
所以說EF默認(rèn)只能連Sql Express版的數(shù)據(jù)庫。SqlConnectionFactory提供一個構(gòu)造函數(shù)重載,可以指定連接字符串,修改默認(rèn)的數(shù)據(jù)庫連接,我們可以在配置文件中添加以下節(jié)點進(jìn)行配置。
復(fù)制代碼 代碼如下:

entityFramework>
defaultConnectionFactory type="System.Data.Entity.Infrastructure.SqlConnectionFactory, EntityFramework">
parameters>
parameter value="Data Source=heqichang-pc; Integrated Security=True; MultipleActiveResultSets=True" />
/parameters>
/defaultConnectionFactory>
/entityFramework>

不過不管怎樣,我覺得還是指定好連接字符串來開發(fā)比較好,排除各種不可控的因素。
檢測字符串截斷錯誤
有時使用EF的時候會出現(xiàn)像以下這樣的錯誤。
 
產(chǎn)生這個錯誤的原因一般都是數(shù)據(jù)庫里設(shè)置的字段長度小于你插入的新數(shù)據(jù)的長度。但是知道原因,要知道具體是哪個字段的長度超出范圍了卻比較困難了,EF給出的信息也不明確,當(dāng)然,如果數(shù)據(jù)庫中的字段少,可以很快篩選出來,但是如果表中的字段非常多,那就麻煩了。這個時候我們就可以用到SQL Server自帶的SQL Server Profiler這個工具了(Express版沒有這個工具)。
假設(shè)我有個tb_Test表,里面有個Name字段,類型為varchar(10)。在運行我們錯誤的程序前,先開啟Profiler,選擇好你連接的數(shù)據(jù)庫開始監(jiān)控。最后就可以看到我們錯誤的SQL語句了。
 
這個工具可以方便的監(jiān)控到EF運行時對數(shù)據(jù)庫的操作,注意上圖,該工具會自動分辨出這是來自Entity Framework的請求,然后下邊是具體的SQL語句。
以上只是我上兩周使用EF時實際遇到的問題總結(jié),在實際中絕對不止上述我遇到的這些問題,歡迎各位園友多多提出哈!
您可能感興趣的文章:
  • 詳解如何在ASP.NET Core中應(yīng)用Entity Framework
  • NopCommerce架構(gòu)分析之(三)EntityFramework數(shù)據(jù)庫初試化及數(shù)據(jù)操作
  • C# Entity Framework中的IQueryable和IQueryProvider詳解
  • 擴(kuò)展 Entity Framework支持復(fù)雜的過濾條件(多個關(guān)鍵字模糊匹配)
  • Entity Framework之DB First方式詳解

標(biāo)簽:蚌埠 大理 衢州 衡水 江蘇 廣元 棗莊 萍鄉(xiāng)

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《使用Entity Framework(4.3.1版本)遇到的問題整理》,本文關(guān)鍵詞  ;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 收縮
    • 微信客服
    • 微信二維碼
    • 電話咨詢

    • 400-1100-266
    怀化市| 山阴县| 拜城县| 二连浩特市| 甘谷县| 泸溪县| 溧水县| 农安县| 鄂尔多斯市| 望奎县| 资阳市| 兰州市| 达拉特旗| 九寨沟县| 临沭县| 泾源县| 峨边| 麦盖提县| 佛学| 繁峙县| 休宁县| 紫金县| 肃南| 贡山| 手游| 积石山| 香港 | 苍南县| 枝江市| 林州市| 吴桥县| 尉氏县| 扶余县| 金阳县| 开鲁县| 江油市| 靖安县| 长垣县| 株洲市| 邢台市| 永安市|