中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Linq結果集形狀怎么實現

發布時間:2021-12-01 15:46:56 來源:億速云 閱讀:91 作者:iii 欄目:編程語言

這篇文章主要介紹“Linq結果集形狀怎么實現”,在日常操作中,相信很多人在Linq結果集形狀怎么實現問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”Linq結果集形狀怎么實現”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

當存儲過程可以返回多個Linq結果集形狀時,返回類型無法強類型化為單個投影形狀。盡管 LINQ to SQL 可以生成所有可能的投影類型,但它無法獲知將以何種順序返回它們。 ResultTypeAttribute 屬性適用于返回多個結果類型的存儲過程,用以指定該過程可以返回的類型的集合。

在下面的 SQL 代碼示例中,Linq結果集形狀取決于輸入(param1 = 1或param1 = 2)。我們不知道先返回哪個投影。

ALTER PROCEDURE [dbo].[SingleRowset_MultiShape]  -- Add the parameters for the stored procedure here  (@param1 int )  AS  BEGIN  -- SET NOCOUNT ON added to prevent extra result sets from  -- interfering with SELECT statements.  SET NOCOUNT ON;  if(@param1 = 1)  SELECT * from Customers as c where c.Region = 'WA' else if (@param1 = 2)  SELECT CustomerID, ContactName, CompanyName from   Customers as c where c.Region = 'WA' END

拖到O/R設計器內,它自動生成了以下代碼段:

[Function(Name="dbo.[Whole Or Partial Customers Set]")]  public ISingleResult<Whole_Or_Partial_Customers_SetResult>   Whole_Or_Partial_Customers_Set([Parameter(DbType="Int")]   System.Nullable<int> param1)  {  IExecuteResult result = this.ExecuteMethodCall(this,   ((MethodInfo)(MethodInfo.GetCurrentMethod())), param1);  return ((ISingleResult<Whole_Or_Partial_Customers_SetResult>)  (result.ReturnValue));  }

但是,VS2008會把多結果集存儲過程識別為單結果集的存儲過程,默認生成的代碼我們要手動修改一下,要求返回多個結果集,像這樣:

[Function(Name="dbo.[Whole Or Partial Customers Set]")]  [ResultType(typeof(WholeCustomersSetResult))]  [ResultType(typeof(PartialCustomersSetResult))]  public IMultipleResults Whole_Or_Partial_Customers_Set([Parameter  (DbType="Int")] System.Nullable<int> param1)  {  IExecuteResult result = this.ExecuteMethodCall(this,   ((MethodInfo)(MethodInfo.GetCurrentMethod())), param1);  return ((IMultipleResults)(result.ReturnValue));  }

我們分別定義了兩個分部類,用于指定返回的類型。這樣就可以使用了,下面代碼直接調用,分別返回各自的結果集合。

//返回全部Customer結果集  IMultipleResults result = db.Whole_Or_Partial_Customers_Set(1);  IEnumerable<WholeCustomersSetResult> shape1 =  result.GetResult<WholeCustomersSetResult>();  foreach (WholeCustomersSetResult compName in shape1)  {  Console.WriteLine(compName.CompanyName);  }  //返回部分Customer結果集  result = db.Whole_Or_Partial_Customers_Set(2);  IEnumerable<PartialCustomersSetResult> shape2 =  result.GetResult<PartialCustomersSetResult>();  foreach (PartialCustomersSetResult con in shape2)  {  Console.WriteLine(con.ContactName);  }

語句描述:這個實例使用存儲過程返回“WA”地區中的一組客戶。返回的Linq結果集形狀取決于傳入的參數。如果參數等于 1,則返回所有客戶屬性。如果參數等于2,則返回ContactName屬性。

到此,關于“Linq結果集形狀怎么實現”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

鄱阳县| 兰州市| 四川省| 青神县| 阳原县| 鸡东县| 林芝县| 利川市| 石景山区| 荥经县| 凤山县| 嫩江县| 华亭县| 蒙阴县| 陇西县| 疏勒县| 泽普县| 西昌市| 谷城县| 德兴市| 兴国县| 镇平县| 烟台市| 伊春市| 长白| 镇坪县| 田东县| 武鸣县| 闸北区| 涞水县| 施秉县| 苍南县| 中超| 诸暨市| 通渭县| 淳安县| 鲁甸县| 涿州市| 津市市| 德钦县| 芜湖县|