自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

深入ADO.NET實體數據模型 增強互通能力

開發(fā) 后端
在這里我們將討論的是ADO.NET實體數據模型多表連接查詢中的實體鍵問題,這也是與.NET互通能力增強的關鍵,希望對大家有所幫助。

ADO.NET是.NET與數據庫互操作的核心,而ADO.NET實體數據庫則增強了.NET應用程序與數據庫的互聯能力,通過ADO.NET實體數據模型我們可以很方便的與底層數據庫進行強類型的數據互操作。大大的方便了設計人員,從而也提高了數據庫操作的安全性。最近在使用到Silverlight的領域數據服務時遇到一個很特別的問題[在應用程序中的結果和數據庫的結果不一樣],經過反復的試驗,終于找到了問題的根源,那就是ADO.NET實體數據模型依賴于實體鍵,它的查詢會生成實體鍵的唯一結果集。

現在來看看具體的操作過程和處理方式:

為了對數據庫的表進行操作,在數據庫的視圖中建立了一個連接兩個原子表的 vw_DesksAndUsers 的視圖,這個視圖旨在為了連接已存在的User表和Desk的數據,于是我做了如下的T-SQL的視圖,如下所示:

捕獲3

在SQL Server 2008中得到的查詢結果如下:

捕獲6

也就是說得到了預期的結果,[這一步很成功]。接下來進行第二步。

第二步:新建一個Silverlight商業(yè)應用程序SilverlightDomainDb,在生成的項目中會支持WCF RIA服務。這是對Silverlight領域服務的支持所必須的。

第三步:在Web項目中添加一個ADO.NET實體數據模型的新項,在向導中選擇相應的數據庫連接和數據表、視圖及存儲過程等,完成以后會生成相應的實體數據類型和上下文,并得到.edmx的模型圖。如下所示:

捕獲2

根據Visual Studio 2010的提示,它為我們生成了兩個實體鍵:DeskId,IsPlaying(這是Desk表中的兩個字段);現在重新生成項目。

第四步:根據實體模型添加Web領域服務項。(在這一步需要添加相應的表和元數據信息)

第五步:Silverlight項目中將數據源所在vw_DesksAndUsers 的Datagrid拖到Home.xaml中,完成、調試。并沒有得到上面的結果,而是生成了如下的Datagrid:

捕獲

經過仔細的觀察,才發(fā)現原來是ADO.NET實體數據模型中的結果集依賴于實體鍵,也就是說Silverlight領域服務會根據實體鍵的唯一生成查詢的結果集,于是就產生了上面的以DeskId為唯一鍵的數據。

處理:

根據以上的分析,要得到預期的結果,必須設置合適的實體鍵,為了不至于影響到底層的SQL數據庫,我們只需要修改.edmx模型圖中的的實體鍵即可(點擊右鍵選中或不選中“實體鍵”):

捕獲4

現在重新生成項目并運行程序,程序得到了預期的結果。

捕獲5

Silverlight商業(yè)應用程序作為一個專為數據顯示而生的模板,為數據庫的呈現提供了友好的界面,由于其優(yōu)化的數據庫的處理方式使得我們在使用時不得不考慮一些它們之間的細微差別[由于在Visual Studio中沒能看到有LINQ生成的T—SQL查詢語句,所以我也只是提供了一個簡單的解決方案而已],我想其深層的原因在于LINQ查詢中生成的T-SQL語句與數據庫中的T-SQL語句不同而產生。  演示http://files.cnblogs.com/suyan010203/SilverlightDomainDb.rar

原文標題:ADO.NET實體數據模型多表連接查詢中的實體鍵問題

鏈接:http://www.cnblogs.com/suyan010203/archive/2010/08/29/1812010.html

【編輯推薦】

  1. Linq匿名類型簡單概述
  2. Linq隨機讀取數據淺析
  3. Linq Lambda表達式全面分析
  4. Linq擴展方法簡單分析
  5. 初探Linq局部變量類型 

 

責任編輯:彭凡 來源: 博客園
相關推薦

2009-11-12 16:39:02

ADO.NET實體數據

2009-12-29 10:26:43

ADO.NET實體框架

2009-11-12 15:00:03

ADO.NET實體數據

2009-12-18 14:37:56

ADO.NET模型

2009-11-03 17:46:50

ADO.NET Sel

2009-11-12 15:12:57

ADO.NET實體框架

2009-12-31 09:18:23

ADO.NET對象模型

2009-12-21 17:29:43

ADO.NET模型

2009-12-31 13:50:46

ADO.NET模型

2009-12-30 14:12:53

ADO.NET Fra

2009-11-03 15:24:14

ADO.NET對象模型

2009-06-18 09:56:44

ADO.NET對象模型

2009-11-12 14:55:16

ADO.NET實體框架

2009-12-23 16:43:34

ADO.NET模型

2009-11-13 15:33:58

ADO.NET數據對象

2009-12-22 14:29:57

ADO.NET模型

2009-11-04 11:40:38

ADO.NET Dat

2009-12-25 14:23:35

ADO.NET設置

2009-11-12 15:38:18

ADO.NET數據平臺

2009-12-28 15:11:36

ADO.NET專家
點贊
收藏

51CTO技術棧公眾號