溫馨提示×

溫馨提示×

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

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

Linq結(jié)果集形狀怎么實(shí)現(xiàn)

發(fā)布時(shí)間:2021-12-01 15:46:56 來源:億速云 閱讀:89 作者:iii 欄目:編程語言

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

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

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

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設(shè)計(jì)器內(nèi),它自動(dòng)生成了以下代碼段:

[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會(huì)把多結(jié)果集存儲(chǔ)過程識(shí)別為單結(jié)果集的存儲(chǔ)過程,默認(rèn)生成的代碼我們要手動(dòng)修改一下,要求返回多個(gè)結(jié)果集,像這樣:

[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));  }

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

//返回全部Customer結(jié)果集  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結(jié)果集  result = db.Whole_Or_Partial_Customers_Set(2);  IEnumerable<PartialCustomersSetResult> shape2 =  result.GetResult<PartialCustomersSetResult>();  foreach (PartialCustomersSetResult con in shape2)  {  Console.WriteLine(con.ContactName);  }

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

到此,關(guān)于“Linq結(jié)果集形狀怎么實(shí)現(xiàn)”的學(xué)習(xí)就結(jié)束了,希望能夠解決大家的疑惑。理論與實(shí)踐的搭配能更好的幫助大家學(xué)習(xí),快去試試吧!若想繼續(xù)學(xué)習(xí)更多相關(guān)知識(shí),請繼續(xù)關(guān)注億速云網(wǎng)站,小編會(huì)繼續(xù)努力為大家?guī)砀鄬?shí)用的文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI