天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

Linq To Sql進階系列(五)Store Procedure篇

系列文章導航:

Linq To Sql進階系列(一)從映射講起

Linq To Sql進階系列(二)M:M關系

Linq To Sql進階系列(三)CUD和Log

Linq To Sql進階系列(四)User Define Function篇

Linq To Sql進階系列(五)Store Procedure篇

Linq To Sql進階系列(六)用object的動態查詢與保存log篇

Linq To Sql進階系列(七)動態查詢續及CLR與SQL在某些細節上的差別


Store Procedure,存儲過程。也是被別人寫過的東西。我習慣性先看別人都寫了點啥,然后才開始想看看自己還要寫點啥。那就先談談它與udf的區別吧。

Linq To Sql進階系列(四)User Define Function篇 中,我們提到了兩者的差別。比如Store Procedure支持多個rowset的,而udf不行。他們還有一些其他的差別。Store Procedure只能返回整型,而udf可以是其他類型,比如char等,除個別類型外,比如imager類型,是不可以做為udf的返回類型的。Store Procedure支持Out Parameter而udf沒有。

1, SingleResultSet
我們先來看這個sprocs.

CREATE PROCEDURE [dbo].[Customers By City]
    
-- Add the parameters for the stored procedure here
    (@param1 NVARCHAR(20))
AS
BEGIN
    
-- SET NOCOUNT ON added to prevent extra result sets from
    -- interfering with SELECT statements.
    SET NOCOUNT ON;
    
SELECT CustomerID, ContactName, CompanyName, City from Customers as c where
 c.City
=@param1
END

系列文章導航:

Linq To Sql進階系列(一)從映射講起

Linq To Sql進階系列(二)M:M關系

Linq To Sql進階系列(三)CUD和Log

Linq To Sql進階系列(四)User Define Function篇

Linq To Sql進階系列(五)Store Procedure篇

Linq To Sql進階系列(六)用object的動態查詢與保存log篇

Linq To Sql進階系列(七)動態查詢續及CLR與SQL在某些細節上的差別


選中該函數后,右擊屬性。就可以使用其他影射類。但是Linq會對返回的rowset做檢查,如果發現返回結果和影射不匹配它會報錯。而且一旦更改了,當你需要改回去的時候,你只能在Designer中刪掉此sprocs,然后重新拖過來。
調用它很簡單,就當作一個函數,但是,這里和普通的linq語句不一樣的地方是,它不是延遲加載的。

            DataClasses1DataContext db = new DataClasses1DataContext();
            db.Log 
= Console.Out;
            var q 
= db.Customers_By_City("London");

系列文章導航:

Linq To Sql進階系列(一)從映射講起

Linq To Sql進階系列(二)M:M關系

Linq To Sql進階系列(三)CUD和Log

Linq To Sql進階系列(四)User Define Function篇

Linq To Sql進階系列(五)Store Procedure篇

Linq To Sql進階系列(六)用object的動態查詢與保存log篇

Linq To Sql進階系列(七)動態查詢續及CLR與SQL在某些細節上的差別


仔細比較他們的區別哦。“好像名字不一樣呢”。暈倒。看主要的。第一個只有一個ElementType子項,而第二個有2個。這個地方其實可以說是OR designer的一個bug。要想修改這個bug,需要更改一個設計,而推動更改設計,比較麻煩。但并不是不能改。如果你認為這個真的很需要,而且對你很重要,你更喜歡用or designer的話,我建議你去下面的社區發帖子。
http://forums.microsoft.com/MSDN/ShowForum.ASPx?ForumID=123&SiteID=1
要求更改此處的問題。因為,我已經無力推動他們修復該bug,ms更樂意聽來自客戶的聲音,說不定你會成功的哦,還有獎勵的哦。
這個sprocs準確的影射代碼為

        [Function(Name="dbo.Get Customer And Orders")]
        [ResultType(
typeof(GetCustomerAndOrdersResult1))]
        [ResultType(
typeof(GetCustomerAndOrdersResult2))]
        
public IMultipleResults GetCustomerAndOrders([Parameter(Name="CustomerID",
DbType
="NChar(5)")] string customerID)
        
{
            IExecuteResult result 
= this.ExecuteMethodCall(this, ((MethodInfo)(MethodInfo.GetCurrentMethod())), customerID);
            
return ((IMultipleResults)(result.ReturnValue));
        }

系列文章導航:

Linq To Sql進階系列(一)從映射講起

Linq To Sql進階系列(二)M:M關系

Linq To Sql進階系列(三)CUD和Log

Linq To Sql進階系列(四)User Define Function篇

Linq To Sql進階系列(五)Store Procedure篇

Linq To Sql進階系列(六)用object的動態查詢與保存log篇

Linq To Sql進階系列(七)動態查詢續及CLR與SQL在某些細節上的差別


3,OutParameters
似乎沒有什么好講的,很簡單,當作ref 的函數參數輸出的。其也只是在生成的函數里加了這么一句
outParameter =  ((System.Nullable<int>)(result.GetParameterValue(1))); 調用result.GetParameterValue方法,大家要記住這個哦。

4,Return Value
呀,把return value丟那里了。的確,Linq曾舍棄過return value.后來在qa的堅持下,dev們決定保留了它。但是,需要你自己去更改code,才能獲得。我們可以從下面這個sprocs上獲得靈感。

CREATE PROCEDURE [dbo].[CustOrderTotal] 
@CustomerID nchar(5),
@TotalSales money OUTPUT
AS
SELECT @TotalSales = SUM(OD.UNITPRICE*(1-OD.DISCOUNT) * OD.QUANTITY)
FROM ORDERS O, "ORDER DETAILS" OD
where O.CUSTOMERID = @CustomerID AND O.ORDERID = OD.ORDERID

it知識庫Linq To Sql進階系列(五)Store Procedure篇,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 久久人妻无码毛片A片麻豆 久久人妻熟女中文字幕AV蜜芽 | 久久国产欧美日韩精品免费 | 黑色丝袜美腿美女被躁翻了 | 91免费网站在线看入口黄 | 2021国产精品久久久久精品免费网 | 嫩草影院未满十八岁禁止入内 | 欧美一区二区视频高清专区 | 后入式啪gif动态图 后入式狂顶免费视频 | www.青青草 | 韩剧甜性涩爱 | 被同桌摸出水来了好爽的视频 | 麻豆精品2021最新 | 国产精品久久久久久人妻香蕉 | 欧美精品一区二区三区视频 | 精品含羞草免费视频观看 | 在线日本高清日本免费 | 最近韩国日本免费观看mv免费版 | 暖暖视频 免费 高清 日本8 | 国产精品综合AV一区二区国产馆 | 女仆乖H调教跪趴 | 日本漫画大全无翼乌 | 成人无码在线视频区 | 四虎永久免费网址 | 甜性涩爱在线播放 | 国产成人自产拍免费视频 | 乳巨揉みま痴汉电车中文字幕动漫 | 超碰人人草在线视频 | 在线播放免费人成毛片视频 | 超碰98人人插 | 一二三四免费中文在线1 | 2020无码最新国产在线观看 | 中文字幕 日韩 无码 在线 | 99热这里只有 精品 99热这里只就有精品22 | 24小时日本高清免费看 | 中文在线观看永久免费 | 久青草国产在线观看视频 | 国产精品永久免费 | 强开少妇嫩苞又嫩又紧九色 | 免费国产久久啪在线 | 人驴交f ee欧美 | 国产激情精品久久久久久碰 |