संग्रहीत प्रक्रिया: Difference between revisions
(Created page with "{{Short description|Subroutine available to applications that access relational database management systems}} एक संग्रहीत कार्यविधि (ज...") |
No edit summary |
||
(12 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Subroutine available to applications that access relational database management systems}} | {{Short description|Subroutine available to applications that access relational database management systems}} | ||
संग्रहीत कार्यविधि (जिसे प्रोक, स्टॉर्प, स्पोक, स्टोप्रो, स्टोरप्रोक, स्टोर्डप्रोक, एसपी, या एसपी भी कहा जाता है) [[सबरूटीन]] है जो उन अनुप्रयोगों के लिए उपलब्ध है जो[[संबंधपरक डेटाबेस प्रबंधन प्रणाली]] (आरडीबीएमएस) तक पहुंचते हैं। ऐसी प्रक्रियाओं को डेटाबेस [[डेटा शब्दकोश]] में संग्रहीत किया जाता है। | |||
संग्रहीत | संग्रहीत कार्य विधियों के उपयोग में डेटा-सत्यापन (डेटाबेस में एकीकृत) या [[अभिगम नियंत्रण]] सम्मिलित है | इसके अतिरिक्त, संग्रहीत कार्य विधियाँ तर्क को शक्तिशाली और केंद्रीकृत कर सकती हैं जो मूल रूप से अनुप्रयोगों में प्रयुक्त किया गया था। समय और स्मृति को बचाने के लिए, व्यापक या जटिल प्रसंस्करण जिसके लिए कई [[SQL|एसक्यूएल]] कथनों के निष्पादन की आवश्यकता होती है, को संग्रहीत कार्य विधियों में सहेजा जा सकता है, और सभी अनुप्रयोग प्रक्रियाओं को पुकारते हैं।संग्रहीत कार्यविधि को दूसरे के अंदर निष्पादित करके नेस्टेड संग्रहीत कार्यविधियों का उपयोग किया जा सकता है। | ||
संग्रहीत कार्यविधियाँ [[परिणाम सेट]] लौटा सकती हैं, अर्थात, | संग्रहीत कार्यविधियाँ [[परिणाम सेट|परिणाम संग्रह]] को लौटा सकती हैं, अर्थात, एक चयन कथन के परिणाम। इस तरह के परिणाम संग्रह को [[कर्सर (डेटाबेस)]] का उपयोग करके, अन्य संग्रहीत प्रक्रियाओं द्वारा, परिणाम-संग्रह लोकेटर को जोड़कर या अनुप्रयोगों द्वारा संसाधित किया जा सकता है। संग्रहीत कार्य विधियों में डेटा और कर्सर को संसाधित करने के लिए घोषित चर भी हो सकते हैं जो इसे तालिका में कई पंक्तियों के माध्यम से लूप करने की अनुमति देते हैं। संग्रहीत-प्रक्रिया प्रवाह-नियंत्रण कथनों में सामान्यतः सम्मिलित होते हैं <code>IF</code>, <code>WHILE</code>, <code>LOOP</code>, <code>REPEAT</code>, और <code>CASE</code> बयान, और बहुत कुछ। संग्रहीत कार्य विधियाँ चर प्राप्त कर सकती हैं, परिणाम वापस कर सकती हैं या चर को संशोधित कर सकती हैं और उन्हें वापस कर सकती हैं, यह इस बात पर निर्भर करता है कि चर कैसे और कहाँ घोषित किया गया है। | ||
== कार्यान्वयन == | == कार्यान्वयन == | ||
संग्रहीत कार्यविधियाँ उपयोगकर्ता-परिभाषित कार्यों (UDFs) के समान हैं। प्रमुख अंतर यह है कि यूडीएफ को एसक्यूएल बयानों के | संग्रहीत कार्यविधियाँ उपयोगकर्ता-परिभाषित कार्यों (UDFs) के समान हैं। प्रमुख अंतर यह है कि यूडीएफ को एसक्यूएल बयानों के अंदर किसी भी अन्य अभिव्यक्ति की तरह उपयोग किया जा सकता है, जबकि संग्रहित प्रक्रियाओं को उपयोग करके प्रयुक्त किया जाना चाहिए <code>CALL</code> कथन है।<ref>{{Cite web |title=Db2 12 - Application programming and SQL - Calling a stored procedure from your application |url=https://www.ibm.com/docs/en/db2-for-zos/12?topic=zos-calling-stored-procedure-from-your-application |access-date=2022-05-26 |website=www.ibm.com |language=en-us}}</ref><syntaxhighlight> | ||
CALL procedure(...) | |||
या | </syntaxhighlight>या<syntaxhighlight> | ||
EXECUTE procedure(...) | |||
</syntaxhighlight>संग्रहीत कार्य विधियों का स्पष्ट और सही कार्यान्वयनडेटाबेस प्रणाली से दूसरे में भिन्न होता है। अधिकांश प्रमुख डेटाबेस विक्रेता किसी न किसी रूप में उनका समर्थन करते हैं। डेटाबेस प्रणाली के आधार पर, संग्रहीत कार्य विधियाँ विभिन्न प्रकार की [[प्रोग्रामिंग भाषा]]ओं में प्रयुक्त की जा सकती हैं, उदाहरण के लिए एसक्यूएल, जावा (प्रोग्रामिंग भाषा), सी (प्रोग्रामिंग भाषा), या [[C++|सी++]]। गैर-एसक्यूएल भाषाओं में लिखी गई संग्रहीत कार्यविधियाँ स्वयं एसक्यूएल कथनों को निष्पादित कर सकती हैं या नहीं भी कर सकती हैं। | |||
संग्रहीत कार्यविधियों के बढ़ते अपनाने के कारण एसक्यूएल:1999 में एसक्यूएल भाषा में प्रक्रियात्मक तत्वों की प्रारंभिक हुई और एसक्यूएल/पीएसएम भाग में एसक्यूएल:2003 मानक। इसने एसक्यूएल को अनिवार्य प्रोग्रामिंग भाषा बना दिया है। अधिकांश डेटाबेस प्रणाली एसक्यूएल/पीएसएम से अधिक मालिकाना और विक्रेता-विशिष्ट एक्सटेंशन प्रदान करते हैं। जावा संग्रहीत कार्यविधियों के लिएमानक विनिर्देश एसक्यूएल/जेआरटी के साथ-साथ उपस्थित है। | |||
संग्रहीत कार्यविधियों के बढ़ते अपनाने के कारण | |||
{| class="wikitable sortable" | {| class="wikitable sortable" | ||
|- | |- | ||
! | ! डेटाबेस सिस्टम | ||
! | ! कार्यान्वयन भाषा | ||
|- | |- | ||
| [[CUBRID]] | | [[CUBRID|कबरिड]] | ||
| [[Java (programming language)| | | [[Java (programming language)|जावा]] | ||
|- | |- | ||
| [[IBM Db2]] | | [[IBM Db2|आईबीएम डीबी2]] | ||
| | | एसक्यूएल पीएल (एसक्यूएल/पीएसएम मानक के करीब) या जावा | ||
|- | |- | ||
| [[Firebird (database server)| | | [[Firebird (database server)|फायरबर्ड]] | ||
| | | पी एसक्यूएल (फ़िराकल ओरेकल के पीएल/एसक्यूएल के कुछ हिस्सों का भी समर्थन करता है) | ||
|- | |- | ||
| [[Informix]] | | [[Informix|इन्फोर्मिक्स]] | ||
| [[Java (programming language)| | | [[Java (programming language)|जावा]] | ||
|- | |- | ||
| [[Interbase]] | | [[Interbase|इंटरबेस]] | ||
| | | संग्रहीत प्रक्रिया और ट्रिगर भाषा | ||
|- | |- | ||
| [[Microsoft SQL Server]] | | [[Microsoft SQL Server|माइक्रोसॉफ्ट एसक्यूएल सर्वर]] | ||
| | | ट्रांजैक्ट-एसक्यूएल और विभिन्न .NET फ्रेमवर्क लैंग्वेज | ||
|- | |- | ||
| [[MySQL]], | | [[MySQL|माय एसक्यूएल]], मारिया डीबी | ||
| | | खुद की संग्रहीत कार्यविधियाँ, एसक्यूएल/पीएसएम मानक का बारीकी से पालन करना | ||
|- | |- | ||
| [[NuoDB]] | | [[NuoDB|नोऊ डीबी]] | ||
| [[SQL | | [[SQL|एसक्यूएल]] या जावा | ||
|- | |- | ||
| [[Virtuoso Universal Server| | | [[Virtuoso Universal Server|ओपनलिंक विर्टौसो]] | ||
| | | कलाप्रवीण व्यक्ति की प्रक्रियाएँ (वीएसपी); जावा, सी और अन्य प्रोग्रामिंग भाषाओं के माध्यम से भी एक्स्टेंसिबल | ||
|- | |- | ||
| [[Oracle database| | | [[Oracle database|ओरेकल]] | ||
| | | पीएल/एसक्यूएल या जावा | ||
|- | |- | ||
| [[PostgreSQL]] | | [[PostgreSQL|पोस्टग्रे एसक्यूएल]] | ||
| | | पीएल/पीजीएसक्यूएल, पीएल/पर्ल या पीएल/पीएचपी जैसी स्वयं की कार्यात्मक भाषाओं का भी उपयोग कर सकता है | ||
|- | |- | ||
| [[SAP HANA]] | | [[SAP HANA|सैप हाना]] | ||
| [https://help.sap.com/viewer/de2486ee947e43e684d39702027f8a94/2.0.03/en-US/297af2926307446cbbfb1a8f96fec941.html | | [https://help.sap.com/viewer/de2486ee947e43e684d39702027f8a94/2.0.03/en-US/297af2926307446cbbfb1a8f96fec941.html एसक्यूएल]स्क्रिप्ट या आर | ||
|- | |- | ||
| [[SAP Adaptive Server Enterprise| | | [[SAP Adaptive Server Enterprise|एसएपी एएसई]] | ||
| [[Transact-SQL]] | | [[Transact-SQL|ट्रांसक्ट-एसक्यूएल]] | ||
|- | |- | ||
| [[SAP SQL Anywhere]] | | [[SAP SQL Anywhere|सैप]] [[SAP SQL Anywhere|एसक्यूएल कहीं भी]] | ||
| [[Transact-SQL]], | | [[Transact-SQL|ट्रांसक्ट-एसक्यूएल]], वाटकॉम एसक्यूएल | ||
|- | |- | ||
| [[SQLite]] | | [[SQLite|एसक्यूलाइट]] | ||
| | | समर्थित नहीं | ||
|} | |} | ||
; | ==== स्थिर एसक्यूएल के साथ तुलना ==== | ||
;ओवरहेड: क्योंकि संग्रहीत कार्यविधि विवरण सीधे डेटाबेस में संग्रहीत किए जाते हैं, वे संकलन ओवरहेड के सभी या कुछ हिस्सों को हटा सकते हैं जो सामान्यतः उन स्थितियों में आवश्यक होते हैं जहां सॉफ़्टवेयर अनुप्रयोग डेटाबेस में इनलाइन (गतिशील) एसक्यूएल प्रश्न भेजते हैं। (चूंकि, अधिकांश डेटाबेस प्रणाली गतिशील एसक्यूएल कथन को दोहराए जाने से बचने के लिए कथन कैश और अन्य विधि को प्रयुक्त करते हैं।) इसके अतिरिक्त, जब वे कुछ पूर्व-संकलित एसक्यूएल से बचते हैं, तो कथन इष्टतम निष्पादन योजना बनाने की जटिलता को जोड़ते हैं क्योंकि एसक्यूएल के सभी तर्क नहीं होते हैं। कथन संकलन समय पर प्रदान किए जाते हैं। विशिष्ट डेटाबेस कार्यान्वयन और विन्यास के आधार पर, संग्रहित प्रक्रियाओं बनाम सामान्य प्रश्नों या उपयोगकर्ता परिभाषित कार्यों से मिश्रित प्रदर्शन परिणाम देखे जा सकते हैं। | |||
;प्रसार यातायात से बचना: संग्रहीत कार्यविधियों का प्रमुख लाभ यह है कि वे सीधे [[डेटाबेस इंजन]] के अंदर चल सकती हैं।उत्पादन प्रणाली में, इसका सामान्यतः कारण है कि प्रक्रियाएं पूरी तरह से विशेष डेटाबेस सर्वर पर चलती हैं, जिसके पास एक्सेस किए जा रहे डेटा तक सीधी पहुंच होती है। यहाँ लाभ यह है कि नेटवर्क संचार निवेश को पूरी तरह से टाला जा सकता है। एसक्यूएल कथनों की जटिल श्रृंखला के लिए यह अधिक महत्वपूर्ण हो जाता है। | |||
'''व्यापार तर्क को समाहित करना''' | |||
संग्रहीत कार्यविधियाँ प्रोग्रामर को डेटाबेस में एपीआई के रूप में व्यावसायिक तर्क को एम्बेड करने की अनुमति देती हैं, जो डेटा प्रबंधन को सरल बना सकता हैं और ग्राहक कार्यक्रमों में कहीं और तर्क को एन्कोड करने की आवश्यकता को कम कर सकती हैं। इसके परिणाम स्वरूप दोषपूर्ण क्लाइंट प्रोग्राम द्वारा डेटा भ्रष्टाचार की संभावना कम हो सकती है। डेटाबेस प्रणाली संग्रहित प्रक्रियाओं की सहायता से डेटा अखंडता और डेटा स्थिरता सुनिश्चित कर सकता है। | |||
; | ;प्रवेश-अधिकारों का प्रत्यायोजन: कई प्रणालियों में, संग्रहीत कार्यविधियों को डेटाबेस तक प्रवेश अधिकार प्रदान किए जा सकते हैं जो उन प्रक्रियाओं को निष्पादित करने वाले उपयोगकर्ताओं के पास सीधे नहीं होते हैं। | ||
'''एसक्यूएल इंजेक्शन हमलों से अल्प सुरक्षा''' | |||
इंजेक्शन हमलों से बचाने के लिए संग्रहीत कार्यविधियों का उपयोग किया जा सकता है। संग्रहीत कार्यविधि पैरामीटर को डेटा के रूप में माना जाएगा, तथापि कोई हमलावर एसक्यूएल आदेश सम्मिलित करता है। साथ ही, कुछ डीबीएमएस पैरामीटर के प्रकार की जाँच करेंगे। चूँकि,संग्रहीत कार्यविधि जो बदले में इनपुट का उपयोग करके गतिशील एसक्यूएल उत्पन्न करती है, जब तक कि उचित सावधानी नहीं बरती जाती है, तब तक एसक्यूएल इंजेक्शन के लिए असुरक्षित है। | |||
== अन्य उपयोग == | == अन्य उपयोग == | ||
कुछ प्रणालियों में, लेनदेन प्रबंधन को नियंत्रित करने के लिए संग्रहित प्रक्रियाओं का उपयोग किया जा सकता है; दूसरों में, संग्रहीत | कुछ प्रणालियों में, लेनदेन प्रबंधन को नियंत्रित करने के लिए संग्रहित प्रक्रियाओं का उपयोग किया जा सकता है; दूसरों में, संग्रहीत कार्य विधियाँ लेन-देन के अंदर चलती हैं जैसे कि लेनदेन उनके लिए प्रभावी रूप से पारदर्शी होते हैं। संग्रहीत प्रक्रियाओं को [[डेटाबेस ट्रिगर]] या स्थिति संभालने वाले से भी प्रयुक्त किया जा सकता है। उदाहरण के लिए,संग्रहीत कार्यविधि को किसी विशिष्ट तालिका में सम्मिलित करके, या किसी तालिका में किसी विशिष्ट क्षेत्र के अद्यतन द्वारा ट्रिगर किया जा सकता है, और संग्रहीत कार्यविधि के अंदर कोड निष्पादित किया जाएगा। कंडीशन हैंडलर के रूप में संग्रहीत कार्यविधियाँ लिखने से डेटाबेस प्रशासक त्रुटियों को पकड़ने के लिए संग्रहीत प्रक्रियाओं का उपयोग करके प्रणाली में त्रुटियों को ट्रैक करने की अनुमति देता है और डेटाबेस या फ़ाइल जैसे बाहरी संसाधन में कुछ स्वरूप जानकारी रिकॉर्ड करता है। | ||
== कार्यों के साथ तुलना == | == कार्यों के साथ तुलना == | ||
* | * फलन उपप्रोग्राम है जो कुछ संगणना करने के लिए लिखा जाता है। | ||
* | * स्केलर फलन केवल मान (या व्यर्थ) लौटाता है, जबकि तालिका फलन (संबंधपरक) तालिका देता है जिसमें शून्य या अधिक पंक्तियाँ होती हैं, प्रत्येक पंक्ति में या अधिक स्तंभ होते हैं। | ||
* | * फलन को वैल्यू वापस करना चाहिए ( वापसी कीवर्ड), किन्तु संग्रहित प्रक्रियाओं के लिए यह अनिवार्य नहीं है। | ||
* संग्रहीत कार्यविधियाँ उपयोग कर सकती हैं | * संग्रहीत कार्यविधियाँ उपयोग कर सकती हैं वापसी कीवर्ड किन्तु बिना किसी मूल्य के पारित किया जा रहा है। | ||
* कार्यों में | * कार्यों में उपयोग किया जा सकता है चयन बयान, परंतु वे कोई डेटा हेरफेर न करें। चूँकि, प्रक्रियाओं को इसमें सम्मिलित नहीं किया जा सकता है। | ||
* | * संग्रहीत कार्यविधि का उपयोग करके कई मान वापस कर सकते हैं <code>OUT</code> पैरामीटर, या कोई मान नहीं देता है। | ||
* | * संग्रहीत प्रक्रिया क्वेरी संकलन समय बचाती है। | ||
* | * संग्रहीत कार्य विधि डेटाबेस वस्तु है। | ||
* | * संग्रहीत कार्य विधि भौतिक वस्तु है। | ||
== | == निर्मित कथन के साथ तुलना == | ||
तैयार बयान | तैयार बयान सामान्य बयान या क्वेरी लेते हैं और इसे पैरामीटर बनाते हैं जिससे बाद में विभिन्न शाब्दिक मान का उपयोग किया जा सके। संग्रहीत प्रक्रियाओं की तरह, वे दक्षता के लिए सर्वर पर संग्रहीत होते हैं और एसक्यूएल इंजेक्शन हमलों से कुछ सुरक्षा प्रदान करते हैं। चूंकि सरल और अधिक घोषणात्मक, तैयार किए गए बयान सामान्यतः प्रक्रियात्मक तर्क का उपयोग करने के लिए नहीं लिखे जाते हैं और चर पर काम नहीं कर सकते हैं। उनके सरल अंतराफलक और क्लाइंट-साइड कार्यान्वयन के कारण, तैयार किए गए कथन डीबीएमएस के बीच अधिक व्यापक रूप से पुन: प्रयोज्य हैं। | ||
== [[स्मार्ट अनुबंध]] | == [[स्मार्ट अनुबंध|स्मार्ट अनुबंधो]] के साथ तुलना == | ||
स्मार्ट | स्मार्ट अनुबंध ऐसा शब्द है जो आरडीबीएमएस के विपरीत [[ब्लॉकचैन|ब्लॉकश्रृंखला]] पर संग्रहीत निष्पादन योग्य कोड पर प्रयुक्त होता है। सार्वजनिक ब्लॉकश्रृंखला नेटवर्क के निष्पादन परिणाम आम सहमति तंत्र पारंपरिक निजी या संघीय डेटाबेस से सिद्धांत रूप में भिन्न होने के अतिरिक्त, वे सामान्य रूप से संग्रहीत प्रक्रियाओं के समान कार्य करते हैं, चूंकि सामान्यतः मूल्य लेनदेन की भावना के साथ है। | ||
== | == हानि == | ||
* संग्रहीत प्रक्रिया भाषाएँ | * संग्रहीत प्रक्रिया भाषाएँ अधिकांशतः विक्रेता-विशिष्ट होती हैं। डेटाबेस विक्रेताओं को बदलने के लिए सामान्यतः वर्तमान संग्रहीत कार्य विधियों को फिर से लिखने की आवश्यकता होती है। | ||
* संग्रहीत प्रक्रियाओं में परिवर्तन अन्य कोड की तुलना में संस्करण नियंत्रण प्रणाली के | * संग्रहीत प्रक्रियाओं में परिवर्तन अन्य कोड की तुलना में संस्करण नियंत्रण प्रणाली के अंदर ट्रैक करना कठिन होता है। सम्मिलित किए जाने के लिए परियोजना इतिहास में संग्रहीत की जाने वाली स्क्रिप्ट के रूप में परिवर्तनों को पुन: प्रस्तुत किया जाना चाहिए, और प्रक्रियाओं में अंतर को मिलाना और सही विधि से ट्रैक करना कठिन हो सकता है। | ||
* संग्रहीत कार्यविधियों में त्रुटियों | * संग्रहीत कार्यविधियों में त्रुटियों कोसंकलन के भाग के रूप में नहीं पकड़ा जा सकता है या किसी आवेदन आईडीई में चरण का निर्माण नहीं किया जा सकता है - यदि कोई संग्रहीत कार्यविधि गुम हो गई है या गलती से हटा दी गई है, तो यह सच है। | ||
* विभिन्न विक्रेताओं की संग्रहीत प्रक्रिया भाषाओं में परिष्कार के विभिन्न स्तर होते हैं। | * विभिन्न विक्रेताओं की संग्रहीत प्रक्रिया भाषाओं में परिष्कार के विभिन्न स्तर होते हैं। | ||
** उदाहरण के लिए, माइक्रोसॉफ्ट के टी-एसक्यूएल की तुलना में पोस्टग्रेस 'पीजीपीएसक्यूएल में अधिक भाषा सुविधाएं (विशेष रूप से | ** उदाहरण के लिए, माइक्रोसॉफ्ट के टी-एसक्यूएल की तुलना में पोस्टग्रेस 'पीजीपीएसक्यूएल में अधिक भाषा सुविधाएं (विशेष रूप से विस्तार के माध्यम से) हैं। | ||
*संग्रहीत कार्यविधियों को लिखने और डिबग करने के लिए उपकरण समर्थन | *संग्रहीत कार्यविधियों को लिखने और डिबग करने के लिए उपकरण समर्थन अधिकांशतः अन्य प्रोग्रामिंग भाषाओं के लिए उतना अच्छा नहीं होता है, किन्तु यह विक्रेताओं और भाषाओं के बीच भिन्न होता है। | ||
** उदाहरण के लिए, | ** उदाहरण के लिए, पी एल/एसक्यूएल और टी-एसक्यूएल दोनों के पास समर्पित आईडीई और डिबगर्स हैं। पीएल/पीजी एसक्यूएल को विभिन्न आईडीई से डिबग किया जा सकता है। | ||
== संदर्भ == | == संदर्भ == | ||
Line 113: | Line 117: | ||
== बाहरी संबंध == | == बाहरी संबंध == | ||
*[http://dev.mysql.com/doc/refman/5.7/en/faqs-stored-procs.html Stored Procedures in | *[http://dev.mysql.com/doc/refman/5.7/en/faqs-stored-procs.html Stored Procedures in Myएसक्यूएल FAQ] | ||
*[http://www.postgresql.org/docs/current/interactive/xplang.html An overview of | *[http://www.postgresql.org/docs/current/interactive/xplang.html An overview of Postgreएसक्यूएल Procedural Language support] | ||
*[http://www.petersap.nl/SybaseWiki/index.php/Stored_procedure Using a stored procedure in Sybase ASE] | *[http://www.petersap.nl/SybaseWiki/index.php/Stored_procedure Using a stored procedure in Sybase ASE] | ||
*[http://infolab.stanford.edu/~ullman/fcdb/oracle/or-plsql.html#procedures PL/ | *[http://infolab.stanford.edu/~ullman/fcdb/oracle/or-plsql.html#procedures PL/एसक्यूएल Procedures] | ||
*[http://download.oracle.com/docs/cd/B28359_01/appdev.111/b28370/toc.htm Oracle Database PL/ | *[http://download.oracle.com/docs/cd/B28359_01/appdev.111/b28370/toc.htm Oracle Database PL/एसक्यूएल Language Reference] | ||
*[https://help.sap.com/viewer/de2486ee947e43e684d39702027f8a94/2.0.03/en-US/297af2926307446cbbfb1a8f96fec941.html SAP HANA | *[https://help.sap.com/viewer/de2486ee947e43e684d39702027f8a94/2.0.03/en-US/297af2926307446cbbfb1a8f96fec941.html SAP HANA एसक्यूएलScript Reference] | ||
{{DEFAULTSORT:Stored Procedure}} | |||
{{DEFAULTSORT:Stored Procedure}} | |||
[[Category: | [[Category:CS1 English-language sources (en)]] | ||
[[Category:Created On 16/02/2023]] | [[Category:Created On 16/02/2023|Stored Procedure]] | ||
[[Category:Lua-based templates|Stored Procedure]] | |||
[[Category:Machine Translated Page|Stored Procedure]] | |||
[[Category:Pages with script errors|Stored Procedure]] | |||
[[Category:Pages with syntax highlighting errors]] | |||
[[Category:Short description with empty Wikidata description|Stored Procedure]] | |||
[[Category:Templates Vigyan Ready|Stored Procedure]] | |||
[[Category:Templates that add a tracking category|Stored Procedure]] | |||
[[Category:Templates that generate short descriptions|Stored Procedure]] | |||
[[Category:Templates using TemplateData|Stored Procedure]] | |||
[[Category:डेटाबेस प्रबंधन तंत्र|Stored Procedure]] | |||
[[Category:सबरूटीन्स|Stored Procedure]] |
Latest revision as of 19:28, 7 March 2023
संग्रहीत कार्यविधि (जिसे प्रोक, स्टॉर्प, स्पोक, स्टोप्रो, स्टोरप्रोक, स्टोर्डप्रोक, एसपी, या एसपी भी कहा जाता है) सबरूटीन है जो उन अनुप्रयोगों के लिए उपलब्ध है जोसंबंधपरक डेटाबेस प्रबंधन प्रणाली (आरडीबीएमएस) तक पहुंचते हैं। ऐसी प्रक्रियाओं को डेटाबेस डेटा शब्दकोश में संग्रहीत किया जाता है।
संग्रहीत कार्य विधियों के उपयोग में डेटा-सत्यापन (डेटाबेस में एकीकृत) या अभिगम नियंत्रण सम्मिलित है | इसके अतिरिक्त, संग्रहीत कार्य विधियाँ तर्क को शक्तिशाली और केंद्रीकृत कर सकती हैं जो मूल रूप से अनुप्रयोगों में प्रयुक्त किया गया था। समय और स्मृति को बचाने के लिए, व्यापक या जटिल प्रसंस्करण जिसके लिए कई एसक्यूएल कथनों के निष्पादन की आवश्यकता होती है, को संग्रहीत कार्य विधियों में सहेजा जा सकता है, और सभी अनुप्रयोग प्रक्रियाओं को पुकारते हैं।संग्रहीत कार्यविधि को दूसरे के अंदर निष्पादित करके नेस्टेड संग्रहीत कार्यविधियों का उपयोग किया जा सकता है।
संग्रहीत कार्यविधियाँ परिणाम संग्रह को लौटा सकती हैं, अर्थात, एक चयन कथन के परिणाम। इस तरह के परिणाम संग्रह को कर्सर (डेटाबेस) का उपयोग करके, अन्य संग्रहीत प्रक्रियाओं द्वारा, परिणाम-संग्रह लोकेटर को जोड़कर या अनुप्रयोगों द्वारा संसाधित किया जा सकता है। संग्रहीत कार्य विधियों में डेटा और कर्सर को संसाधित करने के लिए घोषित चर भी हो सकते हैं जो इसे तालिका में कई पंक्तियों के माध्यम से लूप करने की अनुमति देते हैं। संग्रहीत-प्रक्रिया प्रवाह-नियंत्रण कथनों में सामान्यतः सम्मिलित होते हैं IF
, WHILE
, LOOP
, REPEAT
, और CASE
बयान, और बहुत कुछ। संग्रहीत कार्य विधियाँ चर प्राप्त कर सकती हैं, परिणाम वापस कर सकती हैं या चर को संशोधित कर सकती हैं और उन्हें वापस कर सकती हैं, यह इस बात पर निर्भर करता है कि चर कैसे और कहाँ घोषित किया गया है।
कार्यान्वयन
संग्रहीत कार्यविधियाँ उपयोगकर्ता-परिभाषित कार्यों (UDFs) के समान हैं। प्रमुख अंतर यह है कि यूडीएफ को एसक्यूएल बयानों के अंदर किसी भी अन्य अभिव्यक्ति की तरह उपयोग किया जा सकता है, जबकि संग्रहित प्रक्रियाओं को उपयोग करके प्रयुक्त किया जाना चाहिए CALL
कथन है।[1]
CALL procedure(...)
या
EXECUTE procedure(...)
संग्रहीत कार्य विधियों का स्पष्ट और सही कार्यान्वयनडेटाबेस प्रणाली से दूसरे में भिन्न होता है। अधिकांश प्रमुख डेटाबेस विक्रेता किसी न किसी रूप में उनका समर्थन करते हैं। डेटाबेस प्रणाली के आधार पर, संग्रहीत कार्य विधियाँ विभिन्न प्रकार की प्रोग्रामिंग भाषाओं में प्रयुक्त की जा सकती हैं, उदाहरण के लिए एसक्यूएल, जावा (प्रोग्रामिंग भाषा), सी (प्रोग्रामिंग भाषा), या सी++। गैर-एसक्यूएल भाषाओं में लिखी गई संग्रहीत कार्यविधियाँ स्वयं एसक्यूएल कथनों को निष्पादित कर सकती हैं या नहीं भी कर सकती हैं।
संग्रहीत कार्यविधियों के बढ़ते अपनाने के कारण एसक्यूएल:1999 में एसक्यूएल भाषा में प्रक्रियात्मक तत्वों की प्रारंभिक हुई और एसक्यूएल/पीएसएम भाग में एसक्यूएल:2003 मानक। इसने एसक्यूएल को अनिवार्य प्रोग्रामिंग भाषा बना दिया है। अधिकांश डेटाबेस प्रणाली एसक्यूएल/पीएसएम से अधिक मालिकाना और विक्रेता-विशिष्ट एक्सटेंशन प्रदान करते हैं। जावा संग्रहीत कार्यविधियों के लिएमानक विनिर्देश एसक्यूएल/जेआरटी के साथ-साथ उपस्थित है।
डेटाबेस सिस्टम | कार्यान्वयन भाषा |
---|---|
कबरिड | जावा |
आईबीएम डीबी2 | एसक्यूएल पीएल (एसक्यूएल/पीएसएम मानक के करीब) या जावा |
फायरबर्ड | पी एसक्यूएल (फ़िराकल ओरेकल के पीएल/एसक्यूएल के कुछ हिस्सों का भी समर्थन करता है) |
इन्फोर्मिक्स | जावा |
इंटरबेस | संग्रहीत प्रक्रिया और ट्रिगर भाषा |
माइक्रोसॉफ्ट एसक्यूएल सर्वर | ट्रांजैक्ट-एसक्यूएल और विभिन्न .NET फ्रेमवर्क लैंग्वेज |
माय एसक्यूएल, मारिया डीबी | खुद की संग्रहीत कार्यविधियाँ, एसक्यूएल/पीएसएम मानक का बारीकी से पालन करना |
नोऊ डीबी | एसक्यूएल या जावा |
ओपनलिंक विर्टौसो | कलाप्रवीण व्यक्ति की प्रक्रियाएँ (वीएसपी); जावा, सी और अन्य प्रोग्रामिंग भाषाओं के माध्यम से भी एक्स्टेंसिबल |
ओरेकल | पीएल/एसक्यूएल या जावा |
पोस्टग्रे एसक्यूएल | पीएल/पीजीएसक्यूएल, पीएल/पर्ल या पीएल/पीएचपी जैसी स्वयं की कार्यात्मक भाषाओं का भी उपयोग कर सकता है |
सैप हाना | एसक्यूएलस्क्रिप्ट या आर |
एसएपी एएसई | ट्रांसक्ट-एसक्यूएल |
सैप एसक्यूएल कहीं भी | ट्रांसक्ट-एसक्यूएल, वाटकॉम एसक्यूएल |
एसक्यूलाइट | समर्थित नहीं |
स्थिर एसक्यूएल के साथ तुलना
- ओवरहेड
- क्योंकि संग्रहीत कार्यविधि विवरण सीधे डेटाबेस में संग्रहीत किए जाते हैं, वे संकलन ओवरहेड के सभी या कुछ हिस्सों को हटा सकते हैं जो सामान्यतः उन स्थितियों में आवश्यक होते हैं जहां सॉफ़्टवेयर अनुप्रयोग डेटाबेस में इनलाइन (गतिशील) एसक्यूएल प्रश्न भेजते हैं। (चूंकि, अधिकांश डेटाबेस प्रणाली गतिशील एसक्यूएल कथन को दोहराए जाने से बचने के लिए कथन कैश और अन्य विधि को प्रयुक्त करते हैं।) इसके अतिरिक्त, जब वे कुछ पूर्व-संकलित एसक्यूएल से बचते हैं, तो कथन इष्टतम निष्पादन योजना बनाने की जटिलता को जोड़ते हैं क्योंकि एसक्यूएल के सभी तर्क नहीं होते हैं। कथन संकलन समय पर प्रदान किए जाते हैं। विशिष्ट डेटाबेस कार्यान्वयन और विन्यास के आधार पर, संग्रहित प्रक्रियाओं बनाम सामान्य प्रश्नों या उपयोगकर्ता परिभाषित कार्यों से मिश्रित प्रदर्शन परिणाम देखे जा सकते हैं।
- प्रसार यातायात से बचना
- संग्रहीत कार्यविधियों का प्रमुख लाभ यह है कि वे सीधे डेटाबेस इंजन के अंदर चल सकती हैं।उत्पादन प्रणाली में, इसका सामान्यतः कारण है कि प्रक्रियाएं पूरी तरह से विशेष डेटाबेस सर्वर पर चलती हैं, जिसके पास एक्सेस किए जा रहे डेटा तक सीधी पहुंच होती है। यहाँ लाभ यह है कि नेटवर्क संचार निवेश को पूरी तरह से टाला जा सकता है। एसक्यूएल कथनों की जटिल श्रृंखला के लिए यह अधिक महत्वपूर्ण हो जाता है।
व्यापार तर्क को समाहित करना
संग्रहीत कार्यविधियाँ प्रोग्रामर को डेटाबेस में एपीआई के रूप में व्यावसायिक तर्क को एम्बेड करने की अनुमति देती हैं, जो डेटा प्रबंधन को सरल बना सकता हैं और ग्राहक कार्यक्रमों में कहीं और तर्क को एन्कोड करने की आवश्यकता को कम कर सकती हैं। इसके परिणाम स्वरूप दोषपूर्ण क्लाइंट प्रोग्राम द्वारा डेटा भ्रष्टाचार की संभावना कम हो सकती है। डेटाबेस प्रणाली संग्रहित प्रक्रियाओं की सहायता से डेटा अखंडता और डेटा स्थिरता सुनिश्चित कर सकता है।
- प्रवेश-अधिकारों का प्रत्यायोजन
- कई प्रणालियों में, संग्रहीत कार्यविधियों को डेटाबेस तक प्रवेश अधिकार प्रदान किए जा सकते हैं जो उन प्रक्रियाओं को निष्पादित करने वाले उपयोगकर्ताओं के पास सीधे नहीं होते हैं।
एसक्यूएल इंजेक्शन हमलों से अल्प सुरक्षा
इंजेक्शन हमलों से बचाने के लिए संग्रहीत कार्यविधियों का उपयोग किया जा सकता है। संग्रहीत कार्यविधि पैरामीटर को डेटा के रूप में माना जाएगा, तथापि कोई हमलावर एसक्यूएल आदेश सम्मिलित करता है। साथ ही, कुछ डीबीएमएस पैरामीटर के प्रकार की जाँच करेंगे। चूँकि,संग्रहीत कार्यविधि जो बदले में इनपुट का उपयोग करके गतिशील एसक्यूएल उत्पन्न करती है, जब तक कि उचित सावधानी नहीं बरती जाती है, तब तक एसक्यूएल इंजेक्शन के लिए असुरक्षित है।
अन्य उपयोग
कुछ प्रणालियों में, लेनदेन प्रबंधन को नियंत्रित करने के लिए संग्रहित प्रक्रियाओं का उपयोग किया जा सकता है; दूसरों में, संग्रहीत कार्य विधियाँ लेन-देन के अंदर चलती हैं जैसे कि लेनदेन उनके लिए प्रभावी रूप से पारदर्शी होते हैं। संग्रहीत प्रक्रियाओं को डेटाबेस ट्रिगर या स्थिति संभालने वाले से भी प्रयुक्त किया जा सकता है। उदाहरण के लिए,संग्रहीत कार्यविधि को किसी विशिष्ट तालिका में सम्मिलित करके, या किसी तालिका में किसी विशिष्ट क्षेत्र के अद्यतन द्वारा ट्रिगर किया जा सकता है, और संग्रहीत कार्यविधि के अंदर कोड निष्पादित किया जाएगा। कंडीशन हैंडलर के रूप में संग्रहीत कार्यविधियाँ लिखने से डेटाबेस प्रशासक त्रुटियों को पकड़ने के लिए संग्रहीत प्रक्रियाओं का उपयोग करके प्रणाली में त्रुटियों को ट्रैक करने की अनुमति देता है और डेटाबेस या फ़ाइल जैसे बाहरी संसाधन में कुछ स्वरूप जानकारी रिकॉर्ड करता है।
कार्यों के साथ तुलना
- फलन उपप्रोग्राम है जो कुछ संगणना करने के लिए लिखा जाता है।
- स्केलर फलन केवल मान (या व्यर्थ) लौटाता है, जबकि तालिका फलन (संबंधपरक) तालिका देता है जिसमें शून्य या अधिक पंक्तियाँ होती हैं, प्रत्येक पंक्ति में या अधिक स्तंभ होते हैं।
- फलन को वैल्यू वापस करना चाहिए ( वापसी कीवर्ड), किन्तु संग्रहित प्रक्रियाओं के लिए यह अनिवार्य नहीं है।
- संग्रहीत कार्यविधियाँ उपयोग कर सकती हैं वापसी कीवर्ड किन्तु बिना किसी मूल्य के पारित किया जा रहा है।
- कार्यों में उपयोग किया जा सकता है चयन बयान, परंतु वे कोई डेटा हेरफेर न करें। चूँकि, प्रक्रियाओं को इसमें सम्मिलित नहीं किया जा सकता है।
- संग्रहीत कार्यविधि का उपयोग करके कई मान वापस कर सकते हैं
OUT
पैरामीटर, या कोई मान नहीं देता है। - संग्रहीत प्रक्रिया क्वेरी संकलन समय बचाती है।
- संग्रहीत कार्य विधि डेटाबेस वस्तु है।
- संग्रहीत कार्य विधि भौतिक वस्तु है।
निर्मित कथन के साथ तुलना
तैयार बयान सामान्य बयान या क्वेरी लेते हैं और इसे पैरामीटर बनाते हैं जिससे बाद में विभिन्न शाब्दिक मान का उपयोग किया जा सके। संग्रहीत प्रक्रियाओं की तरह, वे दक्षता के लिए सर्वर पर संग्रहीत होते हैं और एसक्यूएल इंजेक्शन हमलों से कुछ सुरक्षा प्रदान करते हैं। चूंकि सरल और अधिक घोषणात्मक, तैयार किए गए बयान सामान्यतः प्रक्रियात्मक तर्क का उपयोग करने के लिए नहीं लिखे जाते हैं और चर पर काम नहीं कर सकते हैं। उनके सरल अंतराफलक और क्लाइंट-साइड कार्यान्वयन के कारण, तैयार किए गए कथन डीबीएमएस के बीच अधिक व्यापक रूप से पुन: प्रयोज्य हैं।
स्मार्ट अनुबंधो के साथ तुलना
स्मार्ट अनुबंध ऐसा शब्द है जो आरडीबीएमएस के विपरीत ब्लॉकश्रृंखला पर संग्रहीत निष्पादन योग्य कोड पर प्रयुक्त होता है। सार्वजनिक ब्लॉकश्रृंखला नेटवर्क के निष्पादन परिणाम आम सहमति तंत्र पारंपरिक निजी या संघीय डेटाबेस से सिद्धांत रूप में भिन्न होने के अतिरिक्त, वे सामान्य रूप से संग्रहीत प्रक्रियाओं के समान कार्य करते हैं, चूंकि सामान्यतः मूल्य लेनदेन की भावना के साथ है।
हानि
- संग्रहीत प्रक्रिया भाषाएँ अधिकांशतः विक्रेता-विशिष्ट होती हैं। डेटाबेस विक्रेताओं को बदलने के लिए सामान्यतः वर्तमान संग्रहीत कार्य विधियों को फिर से लिखने की आवश्यकता होती है।
- संग्रहीत प्रक्रियाओं में परिवर्तन अन्य कोड की तुलना में संस्करण नियंत्रण प्रणाली के अंदर ट्रैक करना कठिन होता है। सम्मिलित किए जाने के लिए परियोजना इतिहास में संग्रहीत की जाने वाली स्क्रिप्ट के रूप में परिवर्तनों को पुन: प्रस्तुत किया जाना चाहिए, और प्रक्रियाओं में अंतर को मिलाना और सही विधि से ट्रैक करना कठिन हो सकता है।
- संग्रहीत कार्यविधियों में त्रुटियों कोसंकलन के भाग के रूप में नहीं पकड़ा जा सकता है या किसी आवेदन आईडीई में चरण का निर्माण नहीं किया जा सकता है - यदि कोई संग्रहीत कार्यविधि गुम हो गई है या गलती से हटा दी गई है, तो यह सच है।
- विभिन्न विक्रेताओं की संग्रहीत प्रक्रिया भाषाओं में परिष्कार के विभिन्न स्तर होते हैं।
- उदाहरण के लिए, माइक्रोसॉफ्ट के टी-एसक्यूएल की तुलना में पोस्टग्रेस 'पीजीपीएसक्यूएल में अधिक भाषा सुविधाएं (विशेष रूप से विस्तार के माध्यम से) हैं।
- संग्रहीत कार्यविधियों को लिखने और डिबग करने के लिए उपकरण समर्थन अधिकांशतः अन्य प्रोग्रामिंग भाषाओं के लिए उतना अच्छा नहीं होता है, किन्तु यह विक्रेताओं और भाषाओं के बीच भिन्न होता है।
- उदाहरण के लिए, पी एल/एसक्यूएल और टी-एसक्यूएल दोनों के पास समर्पित आईडीई और डिबगर्स हैं। पीएल/पीजी एसक्यूएल को विभिन्न आईडीई से डिबग किया जा सकता है।
संदर्भ
- ↑ "Db2 12 - Application programming and SQL - Calling a stored procedure from your application". www.ibm.com (in English). Retrieved 2022-05-26.