आप DECLARE
का उपयोग नहीं करते हैं तालिका चर लौटाते समय। परिणाम तालिका को RETURNS
में परिभाषित करें खंड।
CREATE Function GetFinancials ()
RETURNS @financials TABLE
(
[a bunch of variable declarations in here]
)
AS
BEGIN
insert into @Financials
[big old SELECT query here - this all works fine, and populates @Financials]
RETURN
END
अपडेट करें
संग्रहीत प्रक्रिया में अंतिम परिणाम कैसे लौटाएं?
create procedure uspGetFinanicals
as
declare @financial table
(
[table definition here]
)
insert into @financial
select dbo.GetFinancials()
select *
from @Financials f1
where f1.TransactionDate = (
select MAX(TransactionDate)
from @Financials
where SalesDocumentItemID = f1.SalesDocumentItemID
)
अपडेट करें
इसे इस्तेमाल करे। पहले चयन के परिणामों को संग्रहीत करने के लिए यूडीएफ के भीतर एक टेबल वैरिएबल बनाएं, फिर अंतिम क्वेरी के परिणाम को रिटर्न वैल्यू में डालें।
CREATE Function GetFinancials ()
RETURNS @financials TABLE
(
[a bunch of variable declarations in here]
)
AS
BEGIN
declare @table table([a bunch of variable declarations in here])
insert into @table
[big old SELECT query here - this all works fine, and populates @Financials]
insert into @Financials
select *
from @table f1
where f1.TransactionDate = (
select MAX(TransactionDate)
from @table
where SalesDocumentItemID = f1.SalesDocumentItemID
)
RETURN
END