SQL सर्वर में, आप CREATE FUNCTION का उपयोग करके एक अदिश उपयोगकर्ता-परिभाषित फ़ंक्शन बना सकते हैं बयान। एक स्केलर यूज़र-डिफ़ाइंड फ़ंक्शन, जिसे अन्यथा स्केलर यूडीएफ के रूप में जाना जाता है, एक यूज़र-डिफ़ाइंड फ़ंक्शन है जो एक एकल मान देता है।
इस लेख में कुछ बुनियादी टी-एसक्यूएल स्केलर यूडीएफ बनाने के उदाहरण हैं।
सिंटैक्स
सबसे पहले, आइए स्केलर यूडीएफ बनाने के लिए सिंटैक्स को देखें।
टी-एसक्यूएल स्केलर यूडीएफ के लिए वाक्य रचना इस प्रकार है:
CREATE [ OR ALTER ] FUNCTION [ schema_name. ] function_name
( [ { @parameter_name [ AS ][ type_schema_name. ] parameter_data_type
[ = default ] [ READONLY ] }
[ ,...n ]
]
)
RETURNS return_data_type
[ WITH <function_option> [ ,...n ] ]
[ AS ]
BEGIN
function_body
RETURN scalar_expression
END
[ ; ]
और सीएलआर स्केलर यूडीएफ के लिए वाक्य रचना:
CREATE [ OR ALTER ] FUNCTION [ schema_name. ] function_name
( { @parameter_name [AS] [ type_schema_name. ] parameter_data_type
[ = default ] }
[ ,...n ]
)
RETURNS { return_data_type }
[ WITH <clr_function_option> [ ,...n ] ]
[ AS ] EXTERNAL NAME
[ ; ]
<function_option> . पर भागों टी-एसक्यूएल फ़ंक्शन और <clr_function_option> . के लिए सीएलआर कार्यों के लिए आप यूडीएफ के लिए विकल्प निर्दिष्ट कर सकते हैं। फ़ंक्शन विकल्पों में एन्क्रिप्शन, स्कीमा बाइंडिंग, एक EXECUTE AS . जोड़ना शामिल है खंड, साथ ही यह निर्दिष्ट करना कि जब कोई NULL मान तर्क के रूप में पारित किया जाता है तो क्या करना है।
तर्कों और फ़ंक्शन विकल्पों की पूरी सूची Microsoft वेबसाइट पर पाई जा सकती है।
Microsoft दस्तावेज़ में बहुत अधिक विवरण शामिल हैं, इसलिए निम्न उदाहरण स्केलर UDF बनाते समय कुछ सामान्य अवधारणाओं और विकल्पों का त्वरित अवलोकन प्रदान करने के उद्देश्य से हैं।
उदाहरण 1 - बेसिक स्केलर UDF
यहां एक उदाहरण दिया गया है जो कोड एक बुनियादी टी-एसक्यूएल स्केलर यूडीएफ बनाने के लिए उपयोग किया जाता है।
CREATE FUNCTION dbo.ufn_discountPrice(
@price DECIMAL(12,2),
@discount DECIMAL(12,2)
)
RETURNS DECIMAL (12,2)
AS
BEGIN
RETURN @price * (1 - @discount);
END;
यह अदिश UDF दो मापदंडों को स्वीकार करता है; @price और @discount . जब भी फ़ंक्शन का आह्वान किया जाता है तो इन्हें फ़ंक्शन में तर्क के रूप में पास किया जाता है। फ़ंक्शन उन तर्कों का मान लेता है, उन मानों का उपयोग करके गणना करता है, फिर परिणामी मान देता है। इस मामले में, रियायती मूल्य वापस कर दिया जाता है।
उदाहरण 2 - UDF को आमंत्रित करें
एक बार यूडीएफ बन जाने के बाद, जब भी आपको इसकी आवश्यकता हो, इसे टी-एसक्यूएल कोड के भीतर लागू किया जा सकता है।
यूडीएफ को लागू करने का एक उदाहरण यहां दिया गया है:
SELECT dbo.ufn_discountPrice(100, .2) AS Result;
परिणाम
+----------+ | Result | |----------| | 80.00 | +----------+
उदाहरण 3 - एक तालिका की क्वेरी करना
स्केलर यूडीएफ क्वेरी डेटाबेस टेबल जैसी चीजें भी कर सकते हैं।
यहां एक है जो किसी दिए गए कलाकार के लिए डेटाबेस में एल्बमों की संख्या देता है।
CREATE FUNCTION dbo.ufn_CountAlbums (@ArtistId int)
RETURNS smallint
AS
BEGIN
DECLARE @AlbumCount int;
SELECT @AlbumCount = COUNT(AlbumId)
FROM Albums
WHERE ArtistId = @ArtistId;
RETURN @AlbumCount;
END;
यह एक अदिश फलन है क्योंकि यह एकल मान लौटाता है। यदि हम एल्बमों की एक सूची वापस करना चाहते हैं, तो हमें तालिका-मूल्यवान फ़ंक्शन का उपयोग करने की आवश्यकता होगी, क्योंकि तालिका-मूल्यवान फ़ंक्शन इसके परिणाम पंक्तियों के एक सेट के रूप में लौटाते हैं।
उदाहरण 4 - स्कीमा बाइंडिंग
जब आप एक उपयोगकर्ता-परिभाषित फ़ंक्शन बनाते हैं जो डेटाबेस में अन्य वस्तुओं पर निर्भर करता है, तो आमतौर पर स्कीमा को यूडीएफ से बांधना एक अच्छा विचार है। यूडीएफ को बाध्य करने वाली स्कीमा यह सुनिश्चित करती है कि अंतर्निहित वस्तुओं में कोई परिवर्तन नहीं किया जा सकता है जो संभावित रूप से कार्य को प्रभावित कर सकता है।
उदाहरण के लिए, आप उस तालिका को छोड़ने में सक्षम नहीं होंगे जो एक स्कीमा बाध्य यूडीएफ अपनी परिभाषा में उपयोग करता है।
स्कीमा को यूडीएफ बाँधने के लिए, WITH SCHEMABINDING का उपयोग करें इसकी परिभाषा में। यूडीएफ में संदर्भित किसी भी ऑब्जेक्ट के लिए आपको दो-भाग नामों का उपयोग करने की भी आवश्यकता है।
यहां पिछले उदाहरण को फिर से लिखा गया है ताकि यह स्कीमा बाध्य हो:
CREATE FUNCTION dbo.ufn_CountAlbums (@ArtistId int)
RETURNS smallint
WITH SCHEMABINDING
AS
BEGIN
DECLARE @AlbumCount int;
SELECT @AlbumCount = COUNT(AlbumId)
FROM dbo.Albums
WHERE ArtistId = @ArtistId;
RETURN @AlbumCount;
END;
इसलिए, मैंने पहले उदाहरण से दो चीजें बदल दीं। मैंने WITH SCHEMABINDING added जोड़ा , और मैंने Albums . बदल दिया करने के लिए dbo.Albums ।
अब यदि कोई उस तालिका को छोड़ने या उसमें अन्य परिवर्तन करने का प्रयास करता है, तो उन्हें एक त्रुटि प्राप्त होगी।
उदाहरण 5 - एन्क्रिप्शन
आप WITH ENCRYPTION का भी उपयोग कर सकते हैं फ़ंक्शन को एन्क्रिप्ट करने के लिए।
CREATE FUNCTION dbo.ufn_CountAlbums (@ArtistId int)
RETURNS smallint
WITH ENCRYPTION
AS
BEGIN
DECLARE @AlbumCount int;
SELECT @AlbumCount = COUNT(AlbumId)
FROM dbo.Albums
WHERE ArtistId = @ArtistId;
RETURN @AlbumCount;
END;
उदाहरण 6 - NULL इनपुट
फ़ंक्शन का आह्वान करते समय, यदि कोई तर्क NULL है, तो फ़ंक्शन का शरीर अभी भी निष्पादित होता है। यानी, जब तक कि आपने स्पष्ट रूप से RETURNS NULL ON NULL INPUT stated न कहा हो फ़ंक्शन की परिभाषा में।
यदि कोई भी तर्क NULL है, तो उस विकल्प को निर्दिष्ट करने पर NULL वापस आ जाएगा।
CREATE FUNCTION dbo.ufn_CountAlbums (@ArtistId int)
RETURNS smallint
WITH RETURNS NULL ON NULL INPUT
AS
BEGIN
DECLARE @AlbumCount int;
SELECT @AlbumCount = COUNT(AlbumId)
FROM dbo.Albums
WHERE ArtistId = @ArtistId;
RETURN @AlbumCount;
END;
जब मैं तर्क के रूप में NULL का उपयोग करके फ़ंक्शन का आह्वान करता हूं:
SELECT dbo.ufn_CountAlbums(NULL) AS Result;
मैंने इस विकल्प के लिए जो निर्दिष्ट किया है, उसके आधार पर मुझे एक अलग परिणाम मिलता है।
जब फ़ंक्शन डिफ़ॉल्ट सेटिंग का उपयोग करता है तो परिणाम यहां दिया गया है (CALLED ON NULL INPUT ):
+----------+ | Result | |----------| | 0 | +----------+
और यहां परिणाम है जब यह RETURNS NULL ON NULL INPUT का उपयोग करता है :
+----------+ | Result | |----------| | NULL | +----------+
उदाहरण 7 - एकाधिक विकल्प
आप कई विकल्पों को अल्पविराम से अलग कर सकते हैं।
यहां एक उदाहरण दिया गया है जो एन्क्रिप्शन और स्कीमा बाइंडिंग दोनों को फ़ंक्शन में जोड़ता है:
CREATE FUNCTION dbo.ufn_CountAlbums (@ArtistId int)
RETURNS smallint
WITH ENCRYPTION, SCHEMABINDING
AS
BEGIN
DECLARE @AlbumCount int;
SELECT @AlbumCount = COUNT(AlbumId)
FROM dbo.Albums
WHERE ArtistId = @ArtistId;
RETURN @AlbumCount;
END;
उदाहरण 8 - एक फ़ंक्शन बदलें
आप CREATE . को बदलकर एक अदिश UDF को बदल सकते हैं ALTER . के साथ ।
ALTER FUNCTION dbo.ufn_CountAlbums (@ArtistId int)
RETURNS smallint
WITH SCHEMABINDING
AS
BEGIN
DECLARE @AlbumCount int;
SELECT @AlbumCount = COUNT(AlbumId)
FROM dbo.Albums
WHERE ArtistId = @ArtistId;
RETURN @AlbumCount;
END;