您好,登錄后才能下訂單哦!
這篇文章主要介紹“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結果集形狀怎么實現”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。