डेटाबेस एप्लिकेशन में मेरे द्वारा काम किया जाने वाला एक सामान्य पैटर्न एक रिपोर्ट या उपयोगिता के लिए एक संग्रहीत कार्यविधि बनाने की आवश्यकता है जिसमें "पूर्वावलोकन मोड" है। जब ऐसी प्रक्रिया अपडेट करती है, तो यह पैरामीटर इंगित करता है कि कार्रवाई के परिणाम वापस आ जाना चाहिए, लेकिन प्रक्रिया वास्तव में डेटाबेस को अपडेट नहीं करना चाहिए।
इसे पूरा करने का एक तरीका केवल if
पैरामीटर के लिए एक बयान लिखना है , और दो पूर्ण कोड ब्लॉक हैं; जिनमें से एक अपडेट करता है और डेटा लौटाता है और दूसरा सिर्फ डेटा लौटाता है। लेकिन कोड के दोहराव और अपेक्षाकृत कम आत्मविश्वास के कारण यह अवांछनीय है कि पूर्वावलोकन डेटा वास्तव में एक अपडेट के साथ क्या होगा, इसका सटीक प्रतिबिंब है।
निम्नलिखित उदाहरण लाइव अपडेट मोड के रूप में पूर्वावलोकन मोड के लिए कोड के सिर्फ एक ब्लॉक का उपयोग करने के लिए लेनदेन की बचत और चर (जो कि टेम्प टेबल के विपरीत लेनदेन से प्रभावित नहीं हैं) का लाभ उठाने का प्रयास करता है।
नोट: लेन-देन रोलबैक एक विकल्प नहीं है क्योंकि यह प्रक्रिया कॉल खुद को लेनदेन में निहित हो सकती है। यह SQL Server 2012 पर परीक्षण किया गया है।
CREATE TABLE dbo.user_table (a int);
GO
CREATE PROCEDURE [dbo].[PREVIEW_EXAMPLE] (
@preview char(1) = 'Y'
) AS
CREATE TABLE #dataset_to_return (a int);
BEGIN TRANSACTION; -- preview mode required infrastructure
DECLARE @output_to_return TABLE (a int);
SAVE TRANSACTION savepoint;
-- do stuff here
INSERT INTO dbo.user_table (a)
OUTPUT inserted.a INTO @output_to_return (a)
VALUES (42);
-- catch preview mode
IF @preview = 'Y'
ROLLBACK TRANSACTION savepoint;
-- save output to temp table if used for return data
INSERT INTO #dataset_to_return (a)
SELECT a FROM @output_to_return;
COMMIT TRANSACTION;
SELECT a AS proc_return_data FROM #dataset_to_return;
RETURN 0;
GO
-- Examples
EXEC dbo.PREVIEW_EXAMPLE @preview = 'Y';
SELECT a AS user_table_after_preview_mode FROM user_table;
EXEC dbo.PREVIEW_EXAMPLE @preview = 'N';
SELECT a AS user_table_after_live_mode FROM user_table;
-- Cleanup
DROP TABLE dbo.user_table;
DROP PROCEDURE dbo.PREVIEW_EXAMPLE;
GO
मैं इस कोड और डिजाइन पैटर्न पर प्रतिक्रिया की तलाश कर रहा हूं, और / या यदि एक ही समस्या के अन्य समाधान विभिन्न स्वरूपों में मौजूद हैं।