亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > .NET > 正文

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

2024-07-10 13:23:21
字體:
來源:轉載
供稿:網友
在這里記錄一下之前使用Entity Framework(4.3.1版本)遇到的問題。
更新沒有設置主鍵的表
在默認情況下,EF不能對一個沒有主鍵的表進行更新、插入和刪除的動作。用xml方式查看edmx文件,可以在SSDL中可以看到如下xml片斷(我定義了一個沒有主鍵的表tb_WithoutKey)。

復制代碼 代碼如下:


<EntitySet 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>


我再加入一個有主鍵的表進行對比,同樣的在SSDL中,可以看到有主鍵的表的定義如下。

復制代碼 代碼如下:


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


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

復制代碼 代碼如下:


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


不過不管怎樣,我覺得還是指定好連接字符串來開發比較好,排除各種不可控的因素。
檢測字符串截斷錯誤
有時使用EF的時候會出現像以下這樣的錯誤。

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

 
產生這個錯誤的原因一般都是數據庫里設置的字段長度小于你插入的新數據的長度。但是知道原因,要知道具體是哪個字段的長度超出范圍了卻比較困難了,EF給出的信息也不明確,當然,如果數據庫中的字段少,可以很快篩選出來,但是如果表中的字段非常多,那就麻煩了。這個時候我們就可以用到SQL Server自帶的SQL Server Profiler這個工具了(Express版沒有這個工具)。
假設我有個tb_Test表,里面有個Name字段,類型為varchar(10)。在運行我們錯誤的程序前,先開啟Profiler,選擇好你連接的數據庫開始監控。最后就可以看到我們錯誤的SQL語句了。

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

 
這個工具可以方便的監控到EF運行時對數據庫的操作,注意上圖,該工具會自動分辨出這是來自Entity Framework的請求,然后下邊是具體的SQL語句。
以上只是我上兩周使用EF時實際遇到的問題總結,在實際中絕對不止上述我遇到的這些問題,歡迎各位園友多多提出哈!
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲成av人影院在线观看| 国产精品永久免费视频| 综合激情国产一区| 91国产精品电影| 国产手机视频精品| 国产成人+综合亚洲+天堂| 91高清视频在线免费观看| 欧美性受xxxx白人性爽| 久久中国妇女中文字幕| 国产在线98福利播放视频| 91老司机在线| 精品亚洲一区二区三区在线观看| 疯狂做受xxxx高潮欧美日本| 国产精品a久久久久久| 久久久免费在线观看| 精品二区三区线观看| 国产成人一区三区| 日韩欧美在线一区| 欧美中文字幕视频| 美女福利精品视频| 精品小视频在线| 国产精品草莓在线免费观看| 91精品国产沙发| 亚洲成在人线av| 欧美激情视频三区| 久久成人18免费网站| 亚洲免费av网址| 亚洲欧美日韩一区二区在线| 中文字幕亚洲一区二区三区| 亚洲第一黄色网| 国产亚洲精品久久久久动| 欧美在线免费视频| 色偷偷88888欧美精品久久久| 国模精品视频一区二区三区| 麻豆乱码国产一区二区三区| 亚洲乱码国产乱码精品精天堂| 久久久噜噜噜久久| 欧洲成人性视频| 日韩在线中文字| 97视频com| 欧美理论片在线观看| 亚洲精品有码在线| 国产精品美女免费| 欧美电影第一页| 日韩av电影在线播放| 日韩免费不卡av| 97色在线视频观看| 久久99热这里只有精品国产| 精品日本高清在线播放| 亚洲成人黄色在线| 日韩av在线免费| 一区三区二区视频| 亚洲欧美一区二区三区情侣bbw| 伊人久久精品视频| 57pao国产精品一区| 日韩在线观看免费全| 欧美色播在线播放| 国产精品成人v| 中文字幕日韩欧美精品在线观看| 久久精品视频99| 国产91av在线| 国产情人节一区| 国产精品一区二区三区毛片淫片| 17婷婷久久www| 欧美成人精品三级在线观看| 日韩福利伦理影院免费| 中文字幕亚洲精品| 黑人巨大精品欧美一区二区免费| 欧美麻豆久久久久久中文| 色综合视频网站| 福利一区福利二区微拍刺激| 日韩欧美亚洲国产一区| 久久国产精品久久久| 国产欧美日韩综合精品| 国产综合久久久久久| 91欧美精品成人综合在线观看| 亚洲精品自拍视频| 国产成人精品av在线| 久热精品在线视频| 欧美日韩国产综合新一区| 欧美激情精品久久久| 欧美激情免费看| 亚洲日本中文字幕免费在线不卡| 久久综合88中文色鬼| 7m第一福利500精品视频| 伊人男人综合视频网| 欧美视频二区36p| 亚洲成人久久一区| 日韩电影免费观看中文字幕| 国产精品v片在线观看不卡| 日韩av在线影视| 亚洲精品欧美日韩专区| 视频在线观看99| 国产精品美女www爽爽爽视频| 欧美尺度大的性做爰视频| 大量国产精品视频| www日韩欧美| 91sa在线看| 国产一区二区三区久久精品| 国产一区二区三区视频免费| 精品久久久久久电影| 92看片淫黄大片欧美看国产片| 欧美成人午夜剧场免费观看| 欧美在线亚洲在线| 91免费人成网站在线观看18| 国产精品成熟老女人| 国产欧美日韩精品在线观看| 97av视频在线| 亚洲欧美国产一本综合首页| 成人国产精品色哟哟| 日韩在线观看免费高清| 亚洲综合大片69999| 狠狠色狠色综合曰曰| 国产91|九色| 亚洲电影天堂av| 亚洲一区二区三| 午夜精品一区二区三区在线视频| 亚洲第一区中文99精品| 日韩av一区二区在线观看| 亚洲最大福利视频网| 欧美极度另类性三渗透| 91精品国产91久久久久久吃药| 国产精品视频资源| 国模gogo一区二区大胆私拍| 亚洲成人1234| 草民午夜欧美限制a级福利片| 欧美又大粗又爽又黄大片视频| 久久色免费在线视频| 91精品成人久久| 日本三级韩国三级久久| 国产精品视频久久久久| 欧美性生交大片免费| 在线播放国产一区中文字幕剧情欧美| 久久精品视频在线| 日韩电影中文 亚洲精品乱码| 欧美激情一二区| 三级精品视频久久久久| 亚洲成人久久一区| 91视频8mav| 日韩av第一页| 久久精品国产一区二区电影| 毛片精品免费在线观看| 日本中文字幕不卡免费| 91香蕉嫩草神马影院在线观看| 亚洲欧美一区二区三区四区| 国产精品爽爽爽爽爽爽在线观看| 亚洲三级黄色在线观看| 精品视频久久久久久| 日韩视频第一页| 一本大道香蕉久在线播放29| 久久视频中文字幕| 欧美三级xxx| 亚洲精品中文字幕有码专区| 97国产精品免费视频| 最新日韩中文字幕| 成人国产精品免费视频| 久久精品91久久久久久再现| 日本一区二三区好的精华液| 日韩一级黄色av| 国产不卡av在线免费观看| 夜夜嗨av一区二区三区免费区| 亚洲人成网在线播放| 懂色aⅴ精品一区二区三区蜜月| 一区二区三区国产视频|