SAP ABAP - एसक्यूएल अवलोकन खोलें

ओपन एसक्यूएल एबीएपी कथनों के सबसेट को इंगित करता है जो वर्तमान एएसएपी के केंद्रीय डेटाबेस में डेटा तक सीधे पहुंच को सक्षम करता है। एसक्यूपी में एसक्यूएल के डेटा मैनिपुलेशन लैंग्वेज की कार्यप्रणाली को खोलें एसक्यूएल स्टेटमेंट को मैप करें जो सभी डेटाबेस सिस्टम द्वारा समर्थित है।

ओपन एसक्यूएल के बयान डेटाबेस इंटरफेस के ओपन एसक्यूएल इंटरफेस में डेटाबेस विशिष्ट एसक्यूएल में बदल जाते हैं। फिर उन्हें डेटाबेस सिस्टम में स्थानांतरित किया जाता है और निष्पादित किया जाता है। ओपन एसक्यूएल स्टेटमेंट का उपयोग एबैप डिक्शनरी में घोषित डेटाबेस टेबल तक पहुंचने के लिए किया जा सकता है। AS ABAP का केंद्रीय डेटाबेस डिफ़ॉल्ट रूप से एक्सेस किया जाता है और माध्यमिक डेटाबेस कनेक्शन के माध्यम से अन्य डेटाबेस तक भी पहुंच संभव है।

जब भी ABAP कार्यक्रम में इनमें से किसी भी कथन का उपयोग किया जाता है, तो यह जांचना महत्वपूर्ण है कि निष्पादित कार्रवाई सफल रही है या नहीं। यदि कोई डेटाबेस तालिका में रिकॉर्ड सम्मिलित करने का प्रयास करता है और इसे सही ढंग से नहीं डाला जाता है, तो यह जानना बहुत आवश्यक है ताकि कार्यक्रम में उचित कार्रवाई की जा सके। यह एक सिस्टम फ़ील्ड का उपयोग करके किया जा सकता है जो पहले से ही उपयोग किया गया है, वह है SY-SUBRC। जब किसी स्टेटमेंट को सफलतापूर्वक निष्पादित किया जाता है, तो SY-SUBRC फ़ील्ड में 0 का मान होगा, इसलिए इसे चेक किया जा सकता है और यदि यह दिखाई देता है तो प्रोग्राम जारी रख सकता है।

DATA स्टेटमेंट का उपयोग कार्य क्षेत्र घोषित करने के लिए किया जाता है। इसे 'wa_customers1' नाम दें। इसके लिए एक डेटा प्रकार घोषित करने के बजाय, टेबल बनाने वाले कई क्षेत्रों को घोषित किया जा सकता है। ऐसा करने का सबसे आसान तरीका LIKE स्टेटमेंट का उपयोग करना है।

INSERT स्टेटमेंट

Wa_customers1 कार्य क्षेत्र को यहां घोषित किया गया है LUST ZCUSTOMERS1 तालिका, एक ही संरचना पर एक तालिका बने बिना ले रही है। यह कार्य क्षेत्र केवल एक रिकॉर्ड संग्रहीत कर सकता है। एक बार जब यह घोषित किया जाता है, तो INSERT विवरण का उपयोग कार्य क्षेत्र और उस तालिका में रिकॉर्ड रखने के लिए किया जा सकता है। यहां कोड 'INSERT ZCUSTOMERS1 FROM wa_customers1' के रूप में पढ़ा जाएगा।

कार्य क्षेत्र को कुछ आंकड़ों से भरना होगा। ZCUSTOMERS1 तालिका से फ़ील्ड नामों का उपयोग करें। यह आगे नेविगेशन द्वारा किया जा सकता है, कोड में तालिका के नाम पर डबल क्लिक करके या एक नया सत्र खोलकर और लेनदेन SE11 का उपयोग करके किया जा सकता है। तब तालिका के क्षेत्रों को ABAP संपादक में कॉपी और पेस्ट किया जा सकता है।

निम्नलिखित कोड स्निपेट है -

DATA wa_customers1 LIKE ZCUSTOMERS1. 
wa_customers1-customer = '100006'. 
wa_customers1-name = 'DAVE'. 
wa_customers1-title = 'MR'. 
wa_customers1-dob = '19931017'. 
INSERT ZCUSTOMERS1 FROM wa_customers1.

CHECK स्टेटमेंट तब निम्नानुसार इस्तेमाल किया जा सकता है। इसका मतलब है कि यदि रिकॉर्ड सही ढंग से डाला गया है, तो सिस्टम इसे निर्दिष्ट करेगा। यदि नहीं, तो SY-SUBRC कोड जो समान शून्य नहीं होगा प्रदर्शित किया जाएगा। निम्नलिखित कोड स्निपेट है -

IF SY-SUBRC = 0. 
   WRITE 'Record Inserted Successfully'.  
ELSE. 
   WRITE: 'The return code is ', SY-SUBRC. 
ENDIF.

प्रोग्राम को जांचें, सहेजें, कोड को सक्रिय करें और फिर परीक्षण करें। आउटपुट विंडो को 'रिकॉर्ड सम्मिलित रूप से सफलतापूर्वक' प्रदर्शित करना चाहिए।

स्पष्ट कथन

CLEAR कथन एक फ़ील्ड या चर को उसके स्थान पर नए डेटा के सम्मिलन के लिए साफ़ करने की अनुमति देता है, जिससे इसे पुन: उपयोग किया जा सकता है। CLEAR कथन आमतौर पर कार्यक्रमों में उपयोग किया जाता है और यह कई बार मौजूदा क्षेत्रों का उपयोग करने की अनुमति देता है।

पिछले कोड स्निपेट में, ZCUSTOMERS1 तालिका में डाले जाने के लिए एक नया रिकॉर्ड बनाने के लिए कार्य क्षेत्र संरचना को डेटा से भर दिया गया है और फिर एक सत्यापन जांच की जाती है। यदि हम एक नया रिकॉर्ड सम्मिलित करना चाहते हैं, तो CLEAR कथन का उपयोग किया जाना चाहिए ताकि यह फिर से नए डेटा से भरा जा सके।

अद्यतन कथन

यदि आप एक ही समय में एक या एक से अधिक मौजूदा रिकॉर्ड अपडेट करना चाहते हैं तो UPDATE स्टेटमेंट का उपयोग करें। INSERT के बयान के समान, एक कार्य क्षेत्र घोषित किया जाता है, नए डेटा से भरा जाता है जिसे बाद में रिकॉर्ड में डाल दिया जाता है क्योंकि कार्यक्रम निष्पादित किया जाता है। पहले INSERT स्टेटमेंट के साथ बनाया गया रिकॉर्ड यहां अपडेट किया जाएगा। बस NAME और TITLE फ़ील्ड में संग्रहीत पाठ को संपादित करें। फिर एक नई लाइन पर, INSERT स्टेटमेंट के लिए उसी संरचना का उपयोग किया जाता है, और इस बार UPDATE स्टेटमेंट का उपयोग करके जैसा कि निम्नलिखित कोड स्निपेट में दिखाया गया है -

DATA wa_customers1 LIKE ZCUSTOMERS1. 
wa_customers1-customer = '100006'. 
wa_customers1-name = 'RICHARD'. 
wa_customers1-title = 'MR'. 
wa_customers1-dob = '19931017'. 
UPDATE ZCUSTOMERS1 FROM wa_customers1.

जैसे ही UPDATE स्टेटमेंट निष्पादित होता है, आप डेटा ब्राउज़र को ABAP डिक्शनरी में देख सकते हैं कि रिकॉर्ड को सफलतापूर्वक अपडेट किया गया है।

आधुनिक बयान

MODIFY स्टेटमेंट को INSERT और UPDATE स्टेटमेंट के संयोजन के रूप में माना जा सकता है। इसका उपयोग या तो एक नया रिकॉर्ड सम्मिलित करने या मौजूदा रिकॉर्ड को संशोधित करने के लिए किया जा सकता है। यह कार्य क्षेत्र में दर्ज किए गए डेटा से रिकॉर्ड को संशोधित करने के लिए पिछले दो बयानों के समान सिंटैक्स का अनुसरण करता है।

जब यह कथन निष्पादित किया जाता है, तो शामिल किए गए प्रमुख फ़ील्ड तालिका में उन लोगों के खिलाफ जाँच की जाएगी। यदि इन प्रमुख फ़ील्ड मानों के साथ कोई रिकॉर्ड पहले से मौजूद है, तो इसे अपडेट किया जाएगा। यदि नहीं, तो एक नया रिकॉर्ड बनाया जाएगा।

नया रिकॉर्ड बनाने के लिए कोड स्निपेट निम्नलिखित है -

CLEAR wa_customers1.
 
DATA wa_customers1 LIKE ZCUSTOMERS1. 
wa_customers1-customer = '100007'. 
wa_customers1-name = 'RALPH'. 
wa_customers1-title = 'MR'. 
wa_customers1-dob = '19910921'. 
MODIFY ZCUSTOMERS1 FROM wa_customers1.

इस उदाहरण में, CLEAR कथन का उपयोग किया जाता है ताकि कार्य क्षेत्र में एक नई प्रविष्टि डाली जा सके, और फिर ग्राहक (संख्या) 100007 को जोड़ा जाए। चूंकि यह एक नया, अद्वितीय कुंजी फ़ील्ड मान है, इसलिए एक नया रिकॉर्ड डाला जाएगा, और एक अन्य सत्यापन जांच निष्पादित की जाती है।

जब इसे निष्पादित किया जाता है और डेटा को डेटा ब्राउज़र में देखा जाता है, तो ग्राहक संख्या 100007 (RPHPH) के लिए एक नया रिकॉर्ड बनाया जाएगा।

उपरोक्त कोड निम्न आउटपुट (तालिका सामग्री) उत्पन्न करता है -