<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關鍵字專題關鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當前位置: 首頁 - 科技 - 知識百科 - 正文

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

        來源:懂視網 責編:小采 時間:2020-11-27 22:41:58
        文檔

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

        使用Entity Framework(4.3.1版本)遇到的問題整理:在這里記錄一下之前使用Entity Framework(4.3.1版本)遇到的問題。 更新沒有設置主鍵的表 在默認情況下,EF不能對一個沒有主鍵的表進行更新、插入和刪除的動作。用xml方式查看edmx文件,可以在SSDL中可以看到如下xml片斷(我定義了一個沒有主鍵的表tb_W
        推薦度:
        導讀使用Entity Framework(4.3.1版本)遇到的問題整理:在這里記錄一下之前使用Entity Framework(4.3.1版本)遇到的問題。 更新沒有設置主鍵的表 在默認情況下,EF不能對一個沒有主鍵的表進行更新、插入和刪除的動作。用xml方式查看edmx文件,可以在SSDL中可以看到如下xml片斷(我定義了一個沒有主鍵的表tb_W

        在這里記錄一下之前使用Entity Framework(4.3.1版本)遇到的問題。
        更新沒有設置主鍵的表
        在默認情況下,EF不能對一個沒有主鍵的表進行更新、插入和刪除的動作。用xml方式查看edmx文件,可以在SSDL中可以看到如下xml片斷(我定義了一個沒有主鍵的表tb_WithoutKey)。
        代碼如下:

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

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

        <EntitySet Name="tb_WithKey" 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的時候會出現像以下這樣的錯誤。
         
        產生這個錯誤的原因一般都是數據庫里設置的字段長度小于你插入的新數據的長度。但是知道原因,要知道具體是哪個字段的長度超出范圍了卻比較困難了,EF給出的信息也不明確,當然,如果數據庫中的字段少,可以很快篩選出來,但是如果表中的字段非常多,那就麻煩了。這個時候我們就可以用到SQL Server自帶的SQL Server Profiler這個工具了(Express版沒有這個工具)。
        假設我有個tb_Test表,里面有個Name字段,類型為varchar(10)。在運行我們錯誤的程序前,先開啟Profiler,選擇好你連接的數據庫開始監控。最后就可以看到我們錯誤的SQL語句了。
         
        這個工具可以方便的監控到EF運行時對數據庫的操作,注意上圖,該工具會自動分辨出這是來自Entity Framework的請求,然后下邊是具體的SQL語句。
        以上只是我上兩周使用EF時實際遇到的問題總結,在實際中絕對不止上述我遇到的這些問題,歡迎各位園友多多提出哈!

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

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

        使用Entity Framework(4.3.1版本)遇到的問題整理:在這里記錄一下之前使用Entity Framework(4.3.1版本)遇到的問題。 更新沒有設置主鍵的表 在默認情況下,EF不能對一個沒有主鍵的表進行更新、插入和刪除的動作。用xml方式查看edmx文件,可以在SSDL中可以看到如下xml片斷(我定義了一個沒有主鍵的表tb_W
        推薦度:
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 免费看一级毛片在线观看精品视频| 亚洲宅男精品一区在线观看| 美女被免费网站视频在线| 国产高清免费观看| 亚洲AV无码成人精品区日韩| 国产精品免费看久久久无码| 久久久久久久久无码精品亚洲日韩 | 亚洲精品无码久久久| 一级毛片免费播放视频| 国产精品亚洲不卡一区二区三区| eeuss影院免费92242部| 亚洲国产精品嫩草影院在线观看 | 亚洲欧洲日产国码一级毛片| 久久成人18免费网站| 亚洲国产精品成人精品无码区| 99热在线免费播放| 67194在线午夜亚洲| 国产免费观看视频| 国产一级高青免费| 亚洲一区二区成人| 日韩视频免费在线| 国产免费牲交视频免费播放| 亚洲国产人成网站在线电影动漫 | 免费大黄网站在线观看| 成人免费无码H在线观看不卡| 亚洲国产精品无码久久SM| 91免费播放人人爽人人快乐| 亚洲狠狠色丁香婷婷综合| 亚洲综合精品香蕉久久网| 1000部拍拍拍18免费网站| 亚洲aⅴ天堂av天堂无码麻豆| 亚洲精品成人在线| 67pao强力打造国产免费| 久久亚洲AV成人无码国产电影 | 免费毛片在线看片免费丝瓜视频| 香蕉视频亚洲一级| 91亚洲国产成人精品下载| 四虎国产精品免费视| 午夜精品射精入后重之免费观看| 亚洲乱色熟女一区二区三区蜜臀| 亚洲人成色77777|