डेटाबेस परीक्षण - त्वरित गाइड

डेटाबेस परीक्षण में डेटा वैधता, डेटा अखंडता परीक्षण, डेटाबेस से संबंधित प्रदर्शन जाँच और डेटाबेस में प्रक्रियाओं, ट्रिगर और कार्यों का परीक्षण शामिल है।

उदाहरण

एक एप्लिकेशन पर विचार करें जो उपयोगकर्ताओं के लिए दिन-प्रतिदिन के लेनदेन के विवरण को कैप्चर करता है और डेटाबेस में विवरण संग्रहीत करता है। डेटाबेस परीक्षण बिंदु से, निम्नलिखित जांच की जानी चाहिए -

  • एप्लिकेशन से लेन-देन की जानकारी डेटाबेस में संग्रहीत की जानी चाहिए और यह उपयोगकर्ता को सही जानकारी प्रदान करनी चाहिए।

  • डेटाबेस पर लोड होने पर जानकारी नहीं खोनी चाहिए।

  • केवल पूर्ण किए गए लेनदेन को संग्रहीत किया जाना चाहिए और सभी अपूर्ण कार्यों को एप्लिकेशन द्वारा समाप्त कर दिया जाना चाहिए।

  • डेटाबेस तक पहुँच प्राधिकरण को बनाए रखा जाना चाहिए। उपयोगकर्ता की जानकारी के लिए कोई अनुचित या अनधिकृत पहुंच प्रदान नहीं की जानी चाहिए।

आपको डेटाबेस परीक्षण करने की आवश्यकता क्यों है?

डेटाबेस परीक्षण क्यों किया जाता है इसके कई कारण हैं। डेटाबेस पर डेटा अखंडता, सत्यापन और डेटा स्थिरता जांच करने की आवश्यकता है क्योंकि बैकएंड सिस्टम डेटा को संग्रहीत करने के लिए जिम्मेदार है और कई उद्देश्य से एक्सेस किया जाता है।

डेटाबेस परीक्षण के कुछ सामान्य कारण नीचे दिए गए हैं -

  • डेटाबेस बैकएंड पर कॉल की जटिलता को कम करने के लिए, डेवलपर्स इसके उपयोग को बढ़ाते हैं View तथा Stored प्रक्रिया।

  • इन Stored प्रक्रियाओं और Viewsग्राहक विवरण (नाम, संपर्क जानकारी, आदि) डालने और बिक्री डेटा जैसे महत्वपूर्ण कार्य शामिल हैं। इन कार्यों को कई स्तरों पर जांचने की आवश्यकता है।

  • Black-box testingफ्रंट-एंड पर प्रदर्शन महत्वपूर्ण है, लेकिन इससे समस्या को अलग करना मुश्किल हो जाता है। बैकएंड सिस्टम पर परीक्षण करने से डेटा की मजबूती बढ़ जाती है। यही कारण है कि डेटाबेस परीक्षण बैक एंड सिस्टम पर किया जाता है।

  • एक डेटाबेस में, डेटा कई अनुप्रयोगों से आता है और एक संभावना है कि डेटाबेस में हानिकारक या गलत डेटा संग्रहीत है। इसलिए, डेटाबेस घटकों को नियमित रूप से जांचने की आवश्यकता है। इसके अलावा, डेटा अखंडता और स्थिरता को नियमित रूप से जांचना चाहिए।

डेटाबेस परीक्षण बनाम फ्रंट-एंड टेस्टिंग

डेटाबेस परीक्षण फ्रंट-एंड UI परीक्षण से अलग है। निम्न तालिका प्रमुख अंतरों पर प्रकाश डालती है -

डेटाबेस परीक्षण यूआई परीक्षण

डेटाबेस परीक्षण को डेटा सत्यापन और अखंडता परीक्षण या बैक-एंड परीक्षण के रूप में जाना जाता है।

UI परीक्षण या फ्रंट-एंड परीक्षण को एप्लिकेशन परीक्षण या GUI परीक्षण भी कहा जाता है।

डेटाबेस परीक्षण में बैक-एंड घटकों का परीक्षण शामिल है, जो उपयोगकर्ताओं को दिखाई नहीं देते हैं।

इसमें डेटाबेस घटक और DBMS सिस्टम जैसे My SQL, Oracle शामिल हैं।

UI परीक्षण में किसी एप्लिकेशन और उसके घटकों जैसे फ़ंक्शंस, ग्राफ़, मेनू, रिपोर्ट इत्यादि की कार्यक्षमता की जाँच करना शामिल है।

ये घटक फ्रंट-एंड डेवलपमेंट टूल जैसे VB.net, C #, डेल्फी, आदि का उपयोग करके बनाए गए हैं।

डेटाबेस परीक्षण में संग्रहीत कार्यविधियाँ, दृश्य, डेटाबेस में स्कीमा, टेबल, इंडेक्स, कुंजियाँ, ट्रिगर, डेटा सत्यापन और डेटा निरंतरता जाँच शामिल है।

UI परीक्षण में एप्लिकेशन, बटन, फ़ॉर्म और फ़ील्ड, कैलेंडर और चित्र, एक पृष्ठ से दूसरे पृष्ठ पर नेविगेशन और एप्लिकेशन की समग्र कार्यक्षमता की कार्यक्षमता की जाँच करना शामिल है।

DB परीक्षण करने के लिए, एक परीक्षक को डेटाबेस अवधारणा का पूरा ज्ञान होना चाहिए - जैसे प्रक्रिया और कार्य, विचार, अनुक्रमणिका, कुंजियाँ और अच्छे हैंड्स-ऑन SQL।

UI परीक्षण करने के लिए, एक परीक्षक को व्यावसायिक आवश्यकताओं, एप्लिकेशन कार्यात्मक ज्ञान, कोडिंग, आदि की अच्छी समझ की आवश्यकता होती है।

डेटा वेब अनुप्रयोगों, इंट्रानेट अनुप्रयोगों और विभिन्न अन्य अनुप्रयोगों पर कई विषम डेटा स्रोतों से आता है।

डेटा मैन्युअल रूप से अनुप्रयोगों में दर्ज किया गया है। इसमें फ्रंट-एंड एप्लिकेशन का कार्यात्मक परीक्षण शामिल है।

एक डेटाबेस के कार्य और संरचना के आधार पर, DB परीक्षण को तीन श्रेणियों में वर्गीकृत किया जा सकता है -

  • Structural Database Testing - यह तालिका और स्तंभ परीक्षण, स्कीमा परीक्षण, संग्रहीत कार्यविधियाँ और विचार परीक्षण, ट्रिगर जाँच इत्यादि से संबंधित है।

  • Functional Testing- इसमें उपयोगकर्ता के दृष्टिकोण से डेटाबेस की कार्यक्षमता की जाँच करना शामिल है। अधिकांश सामान्य प्रकार के कार्यात्मक परीक्षण व्हाइट बॉक्स और ब्लैक बॉक्स परीक्षण हैं।

  • Nonfunctional Testing - इसमें लोड-परीक्षण, डेटाबेस में जोखिम परीक्षण, तनाव परीक्षण, न्यूनतम सिस्टम आवश्यकताएं शामिल हैं, और डेटाबेस के प्रदर्शन से संबंधित है।

संरचनात्मक डेटाबेस परीक्षण

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

संरचनात्मक परीक्षण के संबंध में चर्चा किए गए सामान्य घटक हैं -

स्कीमा / मैपिंग परीक्षण

इसमें डेटाबेस ऑब्जेक्ट मैपिंग के साथ फ्रंट-एंड एप्लिकेशन की वस्तुओं को मान्य करना शामिल है।

स्कीमा परीक्षण में -

  • कभी-कभी ऐसा होता है कि अंतिम उपयोगकर्ता एप्लिकेशन ऑब्जेक्ट सही ढंग से मैप या डेटाबेस ऑब्जेक्ट के साथ संगत नहीं होते हैं। इसलिए, डेटाबेस से जुड़े विभिन्न स्कीमा प्रारूपों की मान्यता की जांच करना आवश्यक है।

  • डेटाबेस में अनमैप्ड ऑब्जेक्ट्स को खोजना आवश्यक है, जैसे टेबल, व्यू, कॉलम आदि की आवश्यकता है।

बाजार में विभिन्न उपकरण हैं जिनका उपयोग स्कीमा में ऑब्जेक्ट मैपिंग करने के लिए किया जा सकता है।

Example - Microsoft SQL सर्वर में, एक परीक्षक डेटाबेस में स्कीमा की जांच और सत्यापन के लिए सरल प्रश्न लिख सकता है।

यदि परीक्षक तालिका संरचना में परिवर्तन करना चाहता है, तो उसे यह सुनिश्चित करना चाहिए कि सभी stored उस तालिका की प्रक्रियाएँ इस परिवर्तन के अनुकूल हैं।

संग्रहीत कार्यविधियाँ और दृश्य परीक्षण

इस परीक्षण में, एक परीक्षक यह सुनिश्चित करता है कि संग्रहीत प्रक्रियाओं और विचारों का मैनुअल निष्पादन आवश्यक परिणाम उत्पन्न करता है।

परीक्षक सुनिश्चित करता है -

  • यदि यह अपेक्षित ट्रिगर्स को अपेक्षित रूप से निष्पादित करने में सक्षम बनाता है।

  • यदि विकास टीम ने प्रक्रियाओं में अनुप्रयोगों के लिए इनपुट पारित करके सभी छोरों और शर्तों को कवर किया है।

  • यदि डेटाबेस में कोई अप्रयुक्त संग्रहीत कार्यविधियाँ हैं।

  • डेटाबेस में आवश्यक तालिकाओं से डेटा प्राप्त होने पर TRIM संचालन ठीक से लागू होता है।

  • परीक्षण के तहत आवेदन की आवश्यकताओं के अनुसार संग्रहीत प्रक्रिया मॉड्यूल के समग्र एकीकरण की मान्यता।

  • अपवाद और त्रुटि हैंडलिंग तंत्र का पालन किया जाता है।

सबसे आम उपकरण जो संग्रहीत प्रक्रियाओं के परीक्षण के लिए उपयोग किए जाते हैं वे हैं LINQ, SP Test tool, आदि।

ट्रिगर परीक्षण

ट्रिगर परीक्षण में, एक परीक्षक को निम्नलिखित सुनिश्चित करने की आवश्यकता होती है -

  • ट्रिगर के कोडिंग चरण के दौरान कोडिंग सम्मेलनों का पालन किया जाता है या नहीं।

  • निष्पादित ट्रिगर्स देखें आवश्यक शर्तों को पूरा करता है।

  • क्या ट्रिगर डेटा को सही ढंग से अपडेट करता है, एक बार उन्हें निष्पादित किया गया है।

  • अद्यतन की वैधता / सम्मिलित करें / हटाएं परीक्षण के तहत कार्यक्षमता लेखन अनुप्रयोग को ट्रिगर करता है।

टेबल्स और स्तंभ परीक्षण

इस परीक्षण में शामिल प्रमुख क्षेत्र हैं -

  • डेटाबेस में डेटा प्रकारों को फ्रंट-एंड एप्लिकेशन में मानों को क्षेत्र में मान्य करना।

  • डेटाबेस में डेटा क्षेत्र की लंबाई को अनुप्रयोग में डेटा प्रकारों की लंबाई को मान्य करना।

  • अनुप्रयोग फ़ील्ड ऑब्जेक्ट से डेटाबेस में कोई भी अनमैप टेबल या कॉलम हैं या नहीं यह जाँच कर।

  • डेटाबेस तालिकाओं और स्तंभों के नामकरण सम्मेलनों को सत्यापित किया जाता है, यदि वे व्यावसायिक आवश्यकता के अनुसार हैं या नहीं।

  • डेटाबेस में कीज़ और इंडेक्स को मान्य करना, अर्थात, टेबल में प्राथमिक और विदेशी कुंजी को आवश्यकता के अनुसार परिभाषित किया गया है।

  • जांचें कि क्या प्राथमिक कुंजी और उनकी संगत विदेशी कुंजी दो तालिकाओं में समान हैं।

  • कुंजियों की अद्वितीय और नहीं पूरी विशेषताओं की जाँच करें।

  • लंबाई और डेटा प्रकार की चाबियाँ और अनुक्रमित आवश्यकता के अनुसार बनाए रखी जाती हैं।

डेटाबेस सर्वर की जाँच करें

डेटाबेस सर्वर जाँच में सत्यापन शामिल है -

  • यदि डेटाबेस सर्वर व्यवसाय की आवश्यकता के अनुसार लेनदेन की अपेक्षित संख्या को संभाल सकता है।

  • यदि डेटाबेस सर्वर का कॉन्फ़िगरेशन विवरण व्यवसाय की आवश्यकता को पूरा करता है।

  • यदि उपयोगकर्ता प्राधिकरण आवश्यकता के अनुसार बनाए रखा है।

क्रियात्मक परीक्षण

कार्यात्मक परीक्षण एक अंतिम-उपयोगकर्ता बिंदु को ध्यान में रखते हुए किया जाता है; क्या अंत-उपयोगकर्ताओं द्वारा चलाए जाने वाले आवश्यक लेनदेन और संचालन व्यावसायिक विनिर्देशों को पूरा करते हैं।

ब्लैक बॉक्स परीक्षण

ब्लैक बॉक्स परीक्षण में कार्यक्षमता की जांच करने के लिए डेटाबेस के एकीकरण को सत्यापित करना शामिल है। परीक्षण के मामले सरल हैं और इनकमिंग डेटा और फ़ंक्शन से आउटगोइंग डेटा को सत्यापित करने के लिए उपयोग किया जाता है।

डेटाबेस की कार्यक्षमता का परीक्षण करने के लिए विभिन्न तकनीकों जैसे कारण-प्रभाव रेखांकन तकनीक, समतुल्य विभाजन और सीमा-मूल्य विश्लेषण का उपयोग किया जाता है।

आईटी इस advantages इस प्रकार हैं -

  • यह काफी सरल है और विकास के शुरुआती चरणों में किया जाता है।
  • व्हाइट-बॉक्स परीक्षण की तुलना में परीक्षण-मामलों के विकास की लागत कम है।

इसके नुकसान इस प्रकार हैं -

  • कुछ त्रुटियों का पता नहीं लगाया जा सकता है
  • यह अज्ञात है कि कार्यक्रम को कितने परीक्षण की आवश्यकता है।

व्हाइट बॉक्स परीक्षण

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

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

श्वेत बॉक्स परीक्षण करने के लिए उपयोग की जाने वाली सबसे आम तकनीकें हैं, हालत कवरेज, निर्णय कवरेज, वक्तव्य कवरेज, आदि।

व्हाइट-बॉक्स परीक्षण में कोडिंग त्रुटियों का पता लगाया जा सकता है, इसलिए डेटाबेस में आंतरिक बग को समाप्त किया जा सकता है। व्हाइट-बॉक्स परीक्षण की सीमा यह है कि एसक्यूएल स्टेटमेंट कवर नहीं किए जाते हैं।

नॉनफंक्शनल टेस्टिंग

नॉनफंक्शनल टेस्टिंग में लोड टेस्टिंग, स्ट्रेस टेस्टिंग, बिजनेस स्पेसिफिकेशन को पूरा करने के लिए मिनिमम सिस्टम रिक्वायरमेंट्स चेक करना, रिस्क फाइंडिंग और डेटाबेस का परफॉर्मेंस ऑप्टिमाइजेशन शामिल है।

लोड परीक्षण

लोड परीक्षण का प्राथमिक लक्ष्य यह जांचना है कि अधिकांश चल रहे लेनदेन का डेटाबेस पर प्रदर्शन प्रभाव है या नहीं।

लोड परीक्षण में, परीक्षक जाँच करता है -

  • कई दूरस्थ उपयोगकर्ताओं के लिए लेनदेन को निष्पादित करने के लिए प्रतिक्रिया समय।
  • विशिष्ट रिकॉर्ड लाने के लिए डेटाबेस द्वारा लिया गया समय।

Examples of load testing in different testing types -

  • डेटाबेस सिस्टम के प्रदर्शन को देखने के लिए बार-बार उपयोग किए जाने वाले लेन-देन को चलाना।
  • इंटरनेट से बड़ी फ़ाइलों की एक श्रृंखला डाउनलोड करना।
  • कंप्यूटर या सर्वर पर एक साथ कई एप्लिकेशन चलाना।

तनाव परीक्षण

सिस्टम ब्रेकपॉइंट की पहचान करने के लिए तनाव परीक्षण किया जाता है। इस परीक्षण में, एप्लिकेशन को इस तरह से लोड किया जाता है कि सिस्टम एक बिंदु पर विफल हो जाता है। इस बिंदु को कहा जाता हैbreakpoint डेटाबेस प्रणाली की।

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

सबसे अधिक इस्तेमाल किया जाने वाला तनाव परीक्षण उपकरण हैं LoadRunner तथा WinRunner

आइए हम ए exampleतनाव परीक्षण। एक CRM एप्लिकेशन 50000 समवर्ती उपयोगकर्ताओं का अधिकतम उपयोगकर्ता लोड ले सकता है। मान लीजिए कि आप लोड को बढ़ाकर 51000 कर देते हैं और कुछ लेनदेन करते हैं जैसे रिकॉर्ड अपडेट करना या प्रविष्टि जोड़ना। जैसे ही आप लेनदेन करते हैं, एप्लिकेशन डेटाबेस सिस्टम के साथ सिंक हो सकता है। तो अगला परीक्षण 52000 के उपयोगकर्ता भार के साथ प्रदर्शन करना है। कभी-कभी, तनाव परीक्षण भी कहा जाता हैFatigue Testing

डेटाबेस परीक्षण करने की प्रक्रिया अन्य अनुप्रयोगों के परीक्षण के समान है। डीबी परीक्षण को नीचे दी गई प्रमुख प्रक्रियाओं के साथ वर्णित किया जा सकता है।

  • पर्यावरण स्थापित करें
  • एक परीक्षण चलाएं
  • परीक्षा परिणाम की जाँच करें
  • अपेक्षित परिणाम के अनुसार मान्य करें
  • संबंधित हितधारकों के निष्कर्षों की रिपोर्ट करें

परीक्षण मामलों को विकसित करने के लिए विभिन्न एसक्यूएल बयानों का उपयोग किया जाता है। सबसे आम एसक्यूएल स्टेटमेंट, जिसका उपयोग DB परीक्षण करने के लिए किया जाता है, हैSelectबयान। इसके अलावा, विभिन्न डीडीएल, डीएमएल, डीसीएल स्टेटमेंट का भी उपयोग किया जा सकता है।

Example - बनाएं, डालें, चुनें, अपडेट करें आदि।

डेटाबेस परीक्षण चरणों

DB परीक्षण एक थकाऊ प्रक्रिया नहीं है और परीक्षण प्रक्रियाओं के अनुसार डेटाबेस परीक्षण जीवनचक्र में विभिन्न चरणों को शामिल करता है।

डेटाबेस परीक्षण में मुख्य चरण हैं -

  • प्रारंभिक अवस्था की जाँच करना
  • परीक्षण चालन
  • अपेक्षित परिणाम के अनुसार सत्यापन को बाहर करें
  • परिणाम उत्पन्न करना

First stageडीबी परीक्षण में परीक्षण प्रक्रिया शुरू करने से पहले डेटाबेस की प्रारंभिक स्थिति की जांच करना है। फिर परिभाषित परीक्षण मामलों के लिए डेटाबेस व्यवहार का परीक्षण किया जाता है। प्राप्त परिणामों के अनुसार, परीक्षण मामलों को अनुकूलित किया जाता है।

सफल डेटाबेस परीक्षण के लिए, नीचे दिए गए वर्कफ़्लो को हर एक परीक्षण द्वारा निष्पादित किया जाता है।

  • Cleaning up the database - यदि डेटाबेस में परीक्षण योग्य डेटा है, तो इसे खाली किया जाना चाहिए।

  • Set up Fixture - इसमें डेटाबेस में डेटा दर्ज करना और डेटाबेस की वर्तमान स्थिति की जांच करना शामिल है।

  • Perform test, verify results and generate results- टेस्ट चलाया जाता है और आउटपुट को सत्यापित किया जाता है। यदि आउटपुट अपेक्षित परिणाम के अनुसार है, तो अगला कदम आवश्यकता के अनुसार परिणाम उत्पन्न करना है। अन्यथा, डेटाबेस में बग को खोजने के लिए परीक्षण दोहराया जाता है।

यह अध्याय सबसे सामान्य तकनीकों की व्याख्या करता है जो डेटाबेस परीक्षण करने के लिए उपयोग की जाती हैं।

डेटाबेस स्कीमा परीक्षण

जैसा कि पहले उल्लेख किया गया है, इसमें स्कीमा में प्रत्येक ऑब्जेक्ट का परीक्षण करना शामिल है।

डेटाबेस और उपकरणों का सत्यापन

  • डेटाबेस का नाम सत्यापित करना
  • डेटा डिवाइस, लॉग डिवाइस और डंप डिवाइस को सत्यापित करना
  • यह सत्यापित करना कि प्रत्येक डेटाबेस के लिए पर्याप्त स्थान आवंटित किया गया है
  • डेटाबेस विकल्प सेटिंग की जाँच करना

टेबल्स, कॉलम, कॉलम प्रकार के नियम जांचते हैं

वास्तविक और लागू सेटिंग के बीच अंतर जानने के लिए नीचे दी गई वस्तुओं को सत्यापित करें।

  • डेटाबेस में सभी तालिकाओं का नाम

  • प्रत्येक तालिका के स्तंभ नाम

  • प्रत्येक तालिका के लिए कॉलम प्रकार

  • NULL मूल्य की जाँच की या नहीं

  • क्या कोई डिफ़ॉल्ट तालिका स्तंभों को सही करने के लिए बाध्य है

  • तालिका के नामों को सही करने और विशेषाधिकारों तक पहुँचने के लिए नियम

कुंजी और सूचकांक

प्रत्येक तालिका में कुंजी और अनुक्रमित सत्यापित करें -

  • प्रत्येक तालिका के लिए प्राथमिक कुंजी

  • प्रत्येक तालिका के लिए विदेशी कुंजियाँ

  • एक विदेशी कुंजी कॉलम और अन्य तालिका में कॉलम के बीच डेटा प्रकार सूचक, क्लस्टर किए गए या गैर-क्लस्टर अद्वितीय या अद्वितीय नहीं हैं

संग्रहीत प्रक्रिया परीक्षण

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

  • संग्रहित प्रक्रिया का नाम

  • पैरामीटर नाम, पैरामीटर प्रकार, आदि।

  • Output- क्या आउटपुट में कई रिकॉर्ड हैं। शून्य पंक्तियों को प्रभावित किया जाता है या केवल कुछ रिकॉर्ड निकाले जाते हैं।

  • संग्रहित प्रक्रिया का कार्य क्या है और एक संग्रहीत प्रक्रिया क्या करने वाली नहीं है?

  • जाँच करने के लिए नमूना इनपुट प्रश्न पास करना अगर कोई संग्रहीत प्रक्रिया सही डेटा निकालती है।

  • Stored Procedure Parameters- सीमा डेटा के साथ और वैध डेटा के साथ संग्रहीत प्रक्रिया को कॉल करें। प्रत्येक पैरामीटर को एक बार अमान्य करें और एक प्रक्रिया चलाएँ।

  • Return values- उन मानों की जांच करें जो संग्रहीत प्रक्रिया द्वारा लौटाए गए हैं। विफलता के मामले में, नॉनज़रो को वापस करना होगा।

  • Error messages check- इस तरह से बदलाव करें कि संग्रहीत प्रक्रिया विफल हो जाए और कम से कम एक बार हर त्रुटि संदेश उत्पन्न हो। जब कोई पूर्वनिर्धारित त्रुटि संदेश नहीं है, तो किसी भी अपवाद परिदृश्य की जाँच करें।

ट्रिगर टेस्ट

ट्रिगर परीक्षण में, परीक्षक को निम्नलिखित कार्य करने होंगे -

  • सुनिश्चित करें कि ट्रिगर नाम सही है।
  • यदि यह एक विशिष्ट तालिका स्तंभ के लिए उत्पन्न होता है, तो ट्रिगर को मान्य करें।
  • ट्रिगर का अद्यतन सत्यापन।
  • मान्य डेटा के साथ रिकॉर्ड अपडेट करें।
  • अमान्य डेटा के साथ रिकॉर्ड अपडेट करें और प्रत्येक ट्रिगर त्रुटि को कवर करें।
  • एक रिकॉर्ड को अपडेट करें जब यह अभी भी अन्य तालिका में एक पंक्ति द्वारा संदर्भित है।
  • विफलता होने पर लेनदेन वापस करना सुनिश्चित करें।
  • ऐसे किसी भी मामले का पता लगाएं, जिसमें एक ट्रिगर को लेन-देन वापस नहीं करना है।

सर्वर सेटअप लिपियों

दो प्रकार के परीक्षण किए जाने चाहिए -

  • खरोंच से डेटाबेस की स्थापना, और
  • किसी मौजूदा डेटाबेस को सेट करने के लिए।

SQL सर्वर का एकीकरण टेस्ट

आपके द्वारा घटक परीक्षण के माध्यम से एकीकरण परीक्षण किए जाने चाहिए।

  • किसी भी टकराव और असंगति को खोजने के लिए अलग-अलग तालिकाओं में रिकॉर्ड्स को चुनने, डालने, अपडेट करने और हटाने के लिए संग्रहीत प्रक्रियाओं को तीव्रता से कहा जाना चाहिए।

  • स्कीमा और ट्रिगर्स के बीच कोई भी टकराव।

  • संग्रहीत प्रक्रियाओं और स्कीमा के बीच कोई भी टकराव।

  • संग्रहीत प्रक्रियाओं और ट्रिगर के बीच कोई भी टकराव।

कार्यात्मक परीक्षण विधि

कार्यक्षमता के अनुसार डेटाबेस को मॉड्यूल में विभाजित करके कार्यात्मक परीक्षण किया जा सकता है। फ़ंक्शंस निम्नलिखित दो प्रकार के होते हैं -

  • Type 1- टाइप 1 परीक्षण में, परियोजना की विशेषताओं का पता लगाएं। प्रत्येक प्रमुख विशेषता के लिए, उस फ़ंक्शन को लागू करने के लिए जिम्मेदार स्कीमा, ट्रिगर और संग्रहीत कार्यविधियों का पता लगाएं और उन्हें एक कार्यात्मक समूह में डालें। फिर प्रत्येक समूह का एक साथ परीक्षण करें।

  • Type 2- टाइप 2 परीक्षण में, बैक-एंड में कार्यात्मक समूहों की सीमा स्पष्ट नहीं है। आप डेटा प्रवाह की जांच कर सकते हैं और देख सकते हैं कि आप डेटा की जाँच कहाँ कर सकते हैं। सामने से शुरू करो।

निम्नलिखित प्रक्रिया होती है -

  • जब किसी सेवा का अनुरोध होता है या डेटा की बचत होती है, तो कुछ संग्रहीत प्रक्रियाएँ कहलाएँगी।

  • प्रक्रियाएँ कुछ तालिकाएँ अद्यतन करेंगी।

  • उन संग्रहीत प्रक्रियाओं का परीक्षण शुरू करने के लिए जगह होगी और उन तालिकाओं का परीक्षण परिणामों की जांच करने का स्थान होगा।

तनाव परीक्षण

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

  • उन कार्यों को आज़माने के लिए टेस्ट स्क्रिप्ट लिखें और प्रत्येक फ़ंक्शन को पूर्ण चक्र में कम से कम एक बार चेक किया जाना चाहिए।

  • एक निश्चित समयावधि के लिए बार-बार परीक्षण लिपियों का प्रदर्शन करें।

  • किसी भी गतिरोध, मेमोरी से बाहर विफलता, डेटा भ्रष्टाचार आदि की जांच करने के लिए लॉग फ़ाइलों का सत्यापन करना।

बेंचमार्क परीक्षण

यदि आपके डेटाबेस में कोई डेटा समस्या या बग नहीं है, तो सिस्टम प्रदर्शन की जाँच की जा सकती है। नीचे दिए गए मापदंडों की जांच करके बेंचमार्क परीक्षण में एक खराब सिस्टम प्रदर्शन पाया जा सकता है -

  • सिस्टम स्तर का प्रदर्शन
  • सबसे अधिक उपयोग किए जाने वाले कार्यों / सुविधाओं की पहचान करें
  • समय - अधिकतम समय, न्यूनतम समय और कार्य करने के लिए औसत समय
  • पहुंच मात्रा

फ्रंट-एंड के माध्यम से एक डेटाबेस का परीक्षण

बैक-एंड बग को फ्रंट-एंड टेस्टिंग करके भी कभी-कभी पाया जा सकता है। आप फ्रंट-एंड टेस्टिंग द्वारा बग्स का पता लगाने के लिए नीचे दिए गए सरल चरणों का पालन कर सकते हैं।

  • फ्रंट-एंड से क्वेरीज़ लिखें और खोजों को जारी करें।

  • एक मौजूदा रिकॉर्ड चुनें, कुछ क्षेत्रों में मूल्यों को बदलें, और रिकॉर्ड को बचाएं। (इसमें अद्यतन विवरण शामिल है या संग्रहीत कार्यविधियाँ अद्यतन करें और ट्रिगर्स अपडेट करें।)

  • फ्रंट-एंड विंडो में एक नया मेनू आइटम डालें। जानकारी भरें और रिकॉर्ड सहेजें। (इसमें INSERT कथन या सम्मिलन संग्रहीत कार्यविधियाँ और विलोपन ट्रिगर शामिल हैं।)

  • मौजूदा रिकॉर्ड चुनें, DELETE या REMOVE बटन पर क्लिक करें, और विलोपन की पुष्टि करें। (इसमें DELETE स्टेटमेंट या डिलीट स्टोरेज प्रोसीजर और डिलीट ट्रिगर्स शामिल हैं।)

  • इन परीक्षण-मामलों को अमान्य डेटा के साथ दोहराएं और देखें कि डेटाबेस कैसे प्रतिक्रिया करता है।

इस अध्याय में, हम विभिन्न परीक्षण विधियों के संबंध में कुछ सामान्य डेटाबेस परीक्षण परिदृश्यों को देखेंगे।

संरचित डेटाबेस परीक्षण

संरचित डेटाबेस परीक्षण के संबंध में सामान्य डेटाबेस परिदृश्य नीचे दिए गए हैं -

  • डेटाबेस का नाम सत्यापित करना, डेटा डिवाइस, लॉग डिवाइस और डंप डिवाइस की पुष्टि करना, यह सत्यापित करना कि क्या प्रत्येक डेटाबेस के लिए पर्याप्त स्थान आवंटित किया गया है और डेटाबेस विकल्प सेटिंग को सत्यापित कर रहा है।

  • डेटाबेस में सभी तालिकाओं के नाम, प्रत्येक तालिका के स्तंभ नाम, प्रत्येक तालिका के लिए स्तंभ प्रकार, शून्य मान की जाँच करें या नहीं। प्रत्येक तालिका में कुंजी और अनुक्रमित सत्यापित करें: प्रत्येक तालिका के लिए प्राथमिक कुंजी, प्रत्येक तालिका के लिए विदेशी कुंजी।

  • एक विदेशी कुंजी कॉलम और अन्य तालिका में कॉलम के बीच डेटा प्रकार सूचक, क्लस्टर किए गए या गैर-क्लस्टर अद्वितीय या अद्वितीय नहीं हैं।

कार्यात्मक डेटाबेस परीक्षण

आम डेटाबेस टेस्ट परिदृश्य के संबंध में Functional Database Testing हैं -

  • स्कीमा, ट्रिगर्स और संग्रहीत कार्यविधियों का पता लगाकर उस फ़ंक्शन को लागू करने और उन्हें एक कार्यात्मक समूह में बनाने के लिए जिम्मेदार है और फिर प्रत्येक समूह को एक साथ परीक्षण किया जा सकता है।

  • डेटा प्रवाह की जाँच करें और देखें कि आप डेटा की जाँच कहाँ कर सकते हैं। सामने से शुरू करो।

गैर-कार्यात्मक डेटाबेस परीक्षण

आम डेटाबेस टेस्ट परिदृश्य के संबंध में Non-Functional Database Testing हैं -

  • प्रमुख कार्यों को आज़माने के लिए परीक्षण स्क्रिप्ट लिखें और प्रत्येक फ़ंक्शन को पूर्ण चक्र में कम से कम एक बार जांचना चाहिए।

  • एक निश्चित समयावधि के लिए बार-बार परीक्षण लिपियों का प्रदर्शन करें।

  • किसी भी गतिरोध, मेमोरी से बाहर विफलता, डेटा भ्रष्टाचार आदि की जांच करने के लिए लॉग फ़ाइलों का सत्यापन करना।

  • सामने के सिरे से प्रश्न लिखें और खोजों को जारी करें। मौजूदा रिकॉर्ड चुनें, कुछ क्षेत्रों में मूल्यों को बदलें और रिकॉर्ड को बचाएं। (इसमें अद्यतन विवरण शामिल है या संग्रहीत कार्यविधियाँ अद्यतन करें, अद्यतन ट्रिगर है।)

  • फ्रंट-एंड विंडो में एक नया मेनू आइटम डालें। जानकारी भरें और रिकॉर्ड सहेजें। (इसमें INSERT कथन या सम्मिलन संग्रहीत कार्यविधियाँ, विलोपन ट्रिगर शामिल हैं।)

  • मौजूदा रिकॉर्ड चुनें, DELETE या REMOVE बटन पर क्लिक करें, और विलोपन की पुष्टि करें। (इसमें DELETE विवरण या विलोपित संग्रहीत कार्यविधियाँ, विलोपन ट्रिगर शामिल हैं।)

  • इन परीक्षण-मामलों को अमान्य डेटा के साथ दोहराएं और देखें कि डेटाबेस कैसे प्रतिक्रिया करता है।

Schemas, tables, stored procedures, तथा Triggersएक डेटाबेस की प्रमुख वस्तुएं हैं। हमने इन डेटा बेस ऑब्जेक्ट के लिए पहले से ही DB परीक्षण प्रकार और परीक्षण परिदृश्य साझा किए हैं।

स्कीमा

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

डेटाबेस स्कीमा एक फॉर्मूला का एक सेट है जिसे एक डेटाबेस पर लगाए गए अखंडता अवरोध कहा जाता है। ये अखंडता अवरोध स्कीमा के कुछ हिस्सों के बीच संगतता सुनिश्चित करते हैं।

एक संबंधपरक डेटाबेस में, स्कीमा में टेबल, फ़ील्ड, व्यू, इंडेक्स, पैकेज, प्रक्रिया, फ़ंक्शन, ट्रिगर, प्रकार, भौतिक विचार, समानार्थी, डेटाबेस लिंक और अन्य तत्व होते हैं।

स्कीमा आम तौर पर एक डेटा शब्दकोश में संग्रहीत की जाती हैं। यद्यपि एक स्कीमा को टेक्स्ट डेटाबेस भाषा में परिभाषित किया गया है, शब्द का उपयोग अक्सर डेटाबेस संरचना के चित्रमय चित्रण को संदर्भित करने के लिए किया जाता है। दूसरे शब्दों में, स्कीमा डेटाबेस की संरचना है जो डेटाबेस में वस्तुओं को परिभाषित करता है।

डेटा वेयरहाउस में उपयोग की जाने वाली सामान्य प्रकार की स्कीमें हैं -

  • स्टार स्कीमा
  • स्नोफ्लेक्स स्कीमा
  • गैलेक्सी स्कीमा

डेटाबेस में तालिकाएँ

संबंधपरक डेटाबेस में, सूचनाओं को पंक्तियों और स्तंभों में व्यवस्थित करने के लिए एक तालिका का उपयोग किया जाता है।

Example - एक ग्राहक तालिका में ग्राहक आईडी, पते, फोन नंबर और कॉलम की एक श्रृंखला जैसी जानकारी होती है।

डेटा का हर एक टुकड़ा तालिका में एक क्षेत्र है। एक कॉलम में एक एकल फ़ील्ड में सभी प्रविष्टियाँ होती हैं, जैसे सभी ग्राहकों के टेलीफोन नंबर। फ़ील्ड्स को रिकॉर्ड के रूप में व्यवस्थित किया जाता है, जो पूरी तरह से सूचनाओं का सेट होता है (जैसे किसी विशेष ग्राहक के बारे में जानकारी का सेट), जिनमें से प्रत्येक में एक पंक्ति शामिल होती है।

संग्रहित प्रक्रियाएं

एक संग्रहीत प्रक्रिया डेटाबेस में संकलित रूप में संग्रहीत SQL कथनों की एक श्रृंखला है और कई कार्यक्रम इसे साझा कर सकते हैं। संग्रहीत प्रक्रियाओं का उपयोग डेटा अखंडता को बनाए रखने, डेटा नियंत्रण पहुंच और उत्पादकता में सुधार करने में सहायक हो सकता है।

ट्रिगर्स

एक डेटाबेस ट्रिगर एक विशेष तालिका या डेटाबेस में कुछ घटनाओं के जवाब में निष्पादित होने वाला कोड है। ट्रिगर का उपयोग ज्यादातर डेटाबेस पर सूचना की अखंडता बनाए रखने के लिए किया जाता है।

डेटाबेस में डेटा इंटीग्रिटी महत्वपूर्ण है। इसमें प्रविष्टि, अद्यतन और विलोपन से पहले डेटा सत्यापन शामिल है। संदर्भ तालिका रिकॉर्ड को मान्य करने के लिए ट्रिगर होना चाहिए।

डेटा वफ़ादारी की जाँच के लिए, आपको निम्नलिखित कार्य करने होंगे -

  • आपको प्रत्येक तालिका में प्रमुख स्तंभों की जांच करने और यह सत्यापित करने की आवश्यकता है कि कोई गलत डेटा मौजूद है या नहीं। (नाम क्षेत्र, नकारात्मक प्रतिशत आदि में वर्ण)

  • असंगत डेटा का पता लगाएं और उन्हें प्रासंगिक तालिकाओं में डालें और देखें कि क्या कोई विफलता होती है।

  • अपने माता-पिता का डेटा डालने से पहले बच्चे का डेटा डालें। किसी अन्य तालिका में डेटा द्वारा संदर्भित अभी भी रिकॉर्ड को हटाने का प्रयास करें।

  • यदि तालिका में कोई डेटा अपडेट किया गया है, तो जांचें कि क्या अन्य प्रासंगिक डेटा भी अपडेट किया गया है। आपको यह सुनिश्चित करने की आवश्यकता है कि प्रतिकृति सर्वर या डेटाबेस सिंक में हैं और इसमें सुसंगत जानकारी है।

डेटाबेस में डेटा मैपिंग एक महत्वपूर्ण अवधारणा है जिसे हर परीक्षक द्वारा मान्य किया जाना चाहिए। आमतौर पर परीक्षकों को यूजर इंटरफेस फ्रंट एंड फील्ड मैपिंग को संबंधित बैक एंड डेटाबेस फील्ड से सत्यापित करना होता है।

यह जानकारी सॉफ़्टवेयर आवश्यकता विनिर्देश या व्यावसायिक आवश्यकता विनिर्देशन SRS / BRS दस्तावेज़ में दी गई है। यदि मैपिंग प्रदान नहीं की जाती है, तो आपको कोडिंग भाग की जांच करने की आवश्यकता है।

जब आप फ्रंट एंड एप्लिकेशन में कोई कार्रवाई करते हैं, तो एक संबंधित CRUD कार्रवाई होती है, और परीक्षक को यह जांचना होता है कि हर आह्वान कार्रवाई सफल है या नहीं।

डेटा मैपिंग के प्रमुख पहलू

नीचे दिए गए डेटा मैपिंग के प्रमुख पहलू हैं -

  • UI / फ्रंट एंड फॉर्म में फ़ील्ड्स की जाँच करने के लिए और संबंधित DB टेबल के साथ लगातार मैप किया जाता है। यह मैपिंग जानकारी आवश्यकताओं दस्तावेजों में परिभाषित की गई है जैसा कि ऊपर उल्लेख किया गया है।

  • किसी अनुप्रयोग के सामने के छोर में की गई किसी भी क्रिया के लिए, CRUD 'क्रिएट, रीट्रीव, अपडेट एंड डिलीट' कार्रवाई अंत छोर पर शुरू की जाती है।

  • एक परीक्षक को यह जांचना होगा कि क्या सही कार्रवाई लागू की गई है और अपने आप में चालान की गई कार्रवाई सफल है या नहीं।

डाटा मैपिंग टेस्टिंग में कदम

नीचे दिए गए चरणों को डेटा मैपिंग परीक्षण के लिए अनुसरण किया गया है -

  • Step 1 - प्रत्येक स्क्रिप्ट में पहले सिंटैक्स त्रुटि की जांच करें।

  • Step 2 - इसके बाद टेबल मैपिंग, कॉलम मैपिंग, और डेटा टाइप मैपिंग की जांच करनी है।

  • Step 3 - लुकअप डेटा मैपिंग सत्यापित करें।

  • Step 4 - प्रत्येक स्क्रिप्ट को चलाएं जब गंतव्य तालिकाओं में रिकॉर्ड मौजूद न हों।

  • Step 5 - प्रत्येक स्क्रिप्ट को चलाएं जब रिकॉर्ड पहले से ही गंतव्य तालिकाओं में मौजूद हों।

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

डेटाबेस लोड परीक्षण आपको प्रदर्शन, विश्वसनीयता और मापनीयता के लिए डेटाबेस एप्लिकेशन को डिजाइन करने में मदद करता है। डेटाबेस अनुप्रयोगों के लोड परीक्षण में अलग-अलग उपयोगकर्ता भार के साथ आपके डेटाबेस अनुप्रयोग के प्रदर्शन और मापनीयता का परीक्षण करना शामिल है।

डेटाबेस लोड परीक्षण में लक्ष्य डेटाबेस अनुप्रयोग के लिए वास्तविक जीवन उपयोगकर्ता लोड का अनुकरण शामिल है। यह निर्धारित करने में आपकी सहायता करता है कि जब एक साथ कई उपयोगकर्ता इसे हिट करते हैं तो आपका डेटाबेस एप्लिकेशन कैसे व्यवहार करता है।

लोड परीक्षण

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

  • कई दूरस्थ उपयोगकर्ताओं के लिए लेनदेन को निष्पादित करने के लिए प्रतिक्रिया समय की जाँच की जानी चाहिए।

  • सामान्य लेनदेन के साथ, आपको इन प्रकार के पीएफ लेनदेन के लिए डेटाबेस के प्रदर्शन की जांच करने के लिए एक संपादन योग्य लेनदेन शामिल करना चाहिए।

  • सामान्य लेनदेन के साथ, आपको इस प्रकार के लेनदेन के लिए डेटाबेस के प्रदर्शन की जांच करने के लिए एक गैर-संपादन लेनदेन शामिल करना चाहिए।

  • विशिष्ट रिकॉर्ड लाने के लिए डेटाबेस द्वारा लिए गए समय की जाँच की जानी चाहिए।

तनाव परीक्षण

प्रणाली की पहचान करने के लिए तनाव परीक्षण किया जाता है breakpoint। यहां एप्लिकेशन को इस तरह से लोड किया जाता है कि सिस्टम एक बिंदु पर विफल हो जाता है। इस बिंदु को डेटाबेस सिस्टम का विराम बिंदु कहा जाता है। तनाव परीक्षण के रूप में भी जाना जाता हैFatigue Testing

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

सबसे आम तनाव परीक्षण उपकरण हैं LoadRunner तथा WinRunner

विक्रेताओं द्वारा प्रदान किए जाने वाले विभिन्न उपकरण हैं जिनका उपयोग टेस्ट डेटा उत्पन्न करने, टेस्ट डेटा को प्रबंधित करने और लोड परीक्षण और प्रतिगमन परीक्षण जैसे डेटाबेस परीक्षण करने के लिए किया जा सकता है।

उपयोग किए जाने वाले कुछ सामान्य उपकरण नीचे दिए गए हैं।

अनु क्रमांक वर्ग विवरण उदाहरण
1

Load Testing Tools

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

वेब प्रदर्शन

रेड व्यू

बुध

2

Data Security Tools

इन उपकरणों का उपयोग सूचना सुरक्षा नियमों के अनुसार अनुपालन और मानकों को लागू करने के लिए किया जाता है।

आईबीएम ऑप्टिमाइज़ डेटा प्राइवेसी

3

Test Data generator tools

एक टेस्टर डेटाबेस टूल के लिए टेस्ट डेटा जेनरेट करने के लिए इन टूल्स का उपयोग करता है। ये ज्यादातर तब आवश्यक होते हैं जब आपके पास भारी मात्रा में डेटा होता है और आपको DB परीक्षण करने के लिए नमूने की आवश्यकता होती है। यह आमतौर पर लोड और तनाव परीक्षण के लिए उपयोग किया जाता है।

डेटा फैक्टरी

DTM डेटा जेनरेटर

टर्बो डेटा

4

Test Data Management Tool

इन उपकरणों का उपयोग परीक्षण डेटा के लिए संस्करण नियंत्रण बनाए रखने के लिए किया जाता है। आपको अपेक्षित परिणामों को परिभाषित करना होगा और फिर आप इसकी तुलना परीक्षणों के वास्तविक परिणामों से करेंगे।

आईबीएम ऑप्टिमाइज़ टेस्ट डेटा मैनेजमेंट

5

Tools to perform Unit Testing

इन उपकरणों का उपयोग आपके डेटाबेस पर प्रतिगमन परीक्षण करने के लिए किया जाता है।

SQLUnit

TSQLUnit

DBFit

DBUnit

संगठनात्मक विकास का सबसे महत्वपूर्ण हिस्सा इसका डेटा है। सिस्टम की विफलता के मामले में, डेटा को पुनर्स्थापित करने की आवश्यकता है। बैक अप डेटाबेस की एक सटीक प्रति है, जो आपको किसी भी डेटा हानि के मामले में आपके डेटा को पुनर्स्थापित करने में मदद करता है।

एक वित्त कंपनी पर विचार करें जिसके पास अपने ग्राहकों से संबंधित डेटा जैसे ए / सी नंबर, ग्राहक नाम, क्रेडिट और डेबिट, अवधि, आदि है। ऐसे संगठन डेटा विफलता के मामले में ऐसी महत्वपूर्ण जानकारी खोने के दबाव से कैसे निपटेंगे?

यही कारण है कि आप डेटा का बैकअप लेते हैं ताकि डिस्क, डिस्क नियंत्रक आदि की किसी भी विफलता के मामले में, आप इसे डेटाबेस में पुनर्स्थापित करने के लिए बैकअप पर भरोसा कर सकें।

डेटा बैकअप के प्रकार

दो प्रकार के बैकअप हैं जिनका उपयोग किया जा सकता है -

  • Physical Backups - भौतिक बैकअप में ओएस की क्षमताओं का उपयोग करके तीसरे पक्ष के बैकअप टूल जैसे कि वेरिटास नेट बैक, आईबीएम टिवोली प्रबंधक या उपयोगकर्ता प्रबंधक बैकअप का उपयोग करना शामिल है।

  • Logical Backups - डेटाबेस के तार्किक बैकअप में टेबल, इंडेक्स, प्रक्रिया आदि जैसे तार्किक वस्तुओं का बैकअप लेना शामिल है।

Example - डेटा बैकअप लेने के लिए आम टूल में से एक है Oracle Recovery Manager (RMAN) कि डेटाबेस बैकअप लेने के लिए एक Oracle उपयोगिता है।

RMAN दो घटक होते हैं -

  • Target database जिसके लिए बैकअप की आवश्यकता होती है।

  • RMAN क्लाइंट का उपयोग डेटा बैकअप लेने के लिए कमांड चलाने के लिए किया जाता है।

BACKUP VALIDATEयदि आप डेटाबेस फ़ाइलों का एक वैध बैकअप बनाने में सक्षम हैं, तो परीक्षण करने के लिए उपयोग किया जाता है। यह सुनिश्चित करता है -

  • यदि बैकअप डेटाबेस की भौतिक या तार्किक वस्तुओं के लिए है।
  • यदि अमूल्य डेटा के लिए नियमित बैकअप सेट किए जाते हैं।
  • यदि बैकअप टूल किसी संगठन की बैकअप आवश्यकताओं को पूरा करता है।

Database recovery testingडेटाबेस पुनर्प्राप्त करने के लिए उपयोग किया जाता है। पुनर्प्राप्ति परीक्षण आपको यह पता लगाने की अनुमति देता है कि क्या एप्लिकेशन ठीक से चल रहा है और आपके पुनर्प्राप्ति विधि ठीक से सेटअप नहीं होने पर खो जाने वाले अमूल्य डेटा को पुनः प्राप्त करने के लिए जांच करेगा।

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

आप डेटाबेस रिकवरी के लिए निम्नलिखित जांच कर सकते हैं -

  • बैकअप सॉफ़्टवेयर में कोई त्रुटि या गलतियाँ और आपको पहले चरण में इन मुद्दों को हल करने की आवश्यकता है।

  • आपको रिकवरी परीक्षण करने की आवश्यकता है ताकि आप जान सकें कि किसी आपातकालीन स्थिति के मामले में क्या करना है।

  • आपको पुनर्प्राप्ति परीक्षण आवश्यकताओं की जांच करने की आवश्यकता है ताकि आप एक प्रभावी वसूली रणनीति के लिए योजना बना सकें।

  • आपको यह भी पता होना चाहिए कि आप दस्तावेजों को कैसे पुनर्प्राप्त कर सकते हैं।

आपको प्रोजेक्ट के शुरुआती चरण में पुनर्प्राप्ति परीक्षण चलाने की आवश्यकता है। यह आपको सिस्टम से हर प्रकार की त्रुटियों को दूर करने और फेंकने की अनुमति देता है। यहां कुछ महत्वपूर्ण बिंदुओं की सूची दी गई है, जिन्हें परीक्षण के समय माना जाना चाहिए -

  • डेटाबेस सिस्टम में परिवर्तन या संशोधन होने पर समय लगता है।

  • वह अवधि जिसके द्वारा आप अपनी पुनर्प्राप्ति योजना का संचालन करना चाहते हैं।

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

डेटाबेस बैकअप और रिकवरी परीक्षण में आम कदम

डेटाबेस रिकवरी परीक्षण में, आपको यह जांचने के लिए वास्तविक वातावरण में परीक्षण चलाने की ज़रूरत है कि क्या सिस्टम या डेटा वास्तव में किसी भी आपदा और व्यावसायिक वातावरण में किसी अन्य अप्रत्याशित घटनाओं के मामले में बरामद किया जा सकता है।

नीचे दिए गए सामान्य कार्य डेटाबेस रिकवरी परीक्षण में दिए गए हैं -

  • डेटाबेस सिस्टम का परीक्षण
  • SQL फ़ाइलों का परीक्षण
  • आंशिक फ़ाइलों का परीक्षण
  • डेटा बैकअप का परीक्षण
  • बैकअप टूल का परीक्षण
  • परीक्षण लॉग बैकअप

डेटाबेस सुरक्षा परीक्षण सुरक्षा तंत्र में खामियों को खोजने के लिए किया जाता है और डेटाबेस प्रणाली की कमजोरियों या कमजोरियों को खोजने के बारे में भी।

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

डेटाबेस सुरक्षा परीक्षण करने के प्राथमिक उद्देश्य नीचे दिए गए हैं -

  • Authentication
  • Authorization
  • Confidentiality
  • Availability
  • Integrity
  • Resilience

एक डेटाबेस सिस्टम पर धमकी के प्रकार

एसक्यूएल इंजेक्षन

यह डेटाबेस सिस्टम में सबसे सामान्य प्रकार का हमला है जिसमें डेटाबेस सिस्टम में दुर्भावनापूर्ण SQL स्टेटमेंट डाले जाते हैं और डेटाबेस सिस्टम से महत्वपूर्ण जानकारी प्राप्त करने के लिए इसे निष्पादित किया जाता है। यह हमला उपयोगकर्ता अनुप्रयोगों के कार्यान्वयन में खामियों का फायदा उठाता है। इसे रोकने के लिए, उपयोगकर्ता इनपुट फ़ील्ड को सावधानीपूर्वक संभाला जाना चाहिए।

डेटाबेस में विशेषाधिकार उन्नयन

इस हमले में, एक उपयोगकर्ता के पास पहले से ही डेटाबेस सिस्टम में कुछ एक्सेस है और वह केवल इस एक्सेस को उच्च स्तर तक ऊंचा करने की कोशिश करता है ताकि वह डेटाबेस सिस्टम में कुछ अनधिकृत गतिविधियां कर सके।

सेवा की मनाई

इस प्रकार के हमले में, एक हमलावर अपने वैध उपयोगकर्ताओं के लिए डेटाबेस सिस्टम या एप्लिकेशन संसाधन अनुपलब्ध बनाता है। एप्लिकेशन को उन तरीकों से भी हमला किया जा सकता है जो एप्लिकेशन को प्रस्तुत करते हैं, और कभी-कभी पूरी मशीन, अनुपयोगी।

डेटा तक अनधिकृत पहुंच

एक अन्य प्रकार का हमला किसी एप्लिकेशन या डेटाबेस सिस्टम में डेटा तक अनधिकृत पहुंच प्राप्त कर रहा है। अनधिकृत पहुंच में शामिल हैं -

  • उपयोगकर्ता आधारित अनुप्रयोगों के माध्यम से डेटा तक अनधिकृत पहुंच
  • दूसरों की पहुंच की निगरानी करके अनधिकृत पहुंच
  • पुन: प्रयोज्य ग्राहक प्रमाणीकरण जानकारी तक अनधिकृत पहुंच

पहचान स्पूफिंग

पहचान स्पूफिंग में, एक हैकर एक उपयोगकर्ता या डिवाइस के क्रेडेंशियल्स का उपयोग नेटवर्क होस्ट के खिलाफ हमले शुरू करने, डेटा चोरी करने या डेटाबेस सिस्टम पर पहुंच नियंत्रण बायपास करने के लिए करता है। इस हमले को रोकने के लिए आईटी-इन्फ्रास्ट्रक्चर और नेटवर्क-स्तरीय शमन की आवश्यकता है।

डेटा मेनिपुलेशन

डेटा हेरफेर हमले में, एक हैकर कुछ लाभ प्राप्त करने या डेटाबेस मालिकों की छवि को नुकसान पहुंचाने के लिए डेटा बदलता है।

डेटाबेस सुरक्षा परीक्षण तकनीक

भेदन परीक्षण

एक प्रवेश परीक्षा एक कंप्यूटर सिस्टम पर सुरक्षा खामियों को खोजने के इरादे से हमला है, जो संभावित रूप से इसे प्राप्त कर रहा है, इसकी कार्यक्षमता और डेटा।

जोखिम ढूँढना

जोखिम ढूँढना नुकसान के प्रकार और जोखिम की घटना की संभावना से जुड़े जोखिम का आकलन और निर्णय लेने की एक प्रक्रिया है। यह विभिन्न साक्षात्कारों, चर्चाओं और विश्लेषण द्वारा संगठन के भीतर निर्धारित किया जाता है।

एसक्यूएल इंजेक्शन टेस्ट

इसमें एप्लिकेशन फ़ील्ड में उपयोगकर्ता इनपुट की जाँच करना शामिल है। उदाहरण के लिए, ',' या ';' उपयोगकर्ता एप्लिकेशन में किसी भी पाठ बॉक्स में अनुमति नहीं दी जानी चाहिए। जब डेटाबेस त्रुटि होती है, तो इसका मतलब है कि उपयोगकर्ता इनपुट को कुछ क्वेरी में डाला जाता है, जिसे बाद में एप्लिकेशन द्वारा निष्पादित किया जाता है। ऐसे मामले में, एप्लिकेशन SQL इंजेक्शन के लिए असुरक्षित है।

ये हमले डेटा के लिए एक बड़ा खतरा हैं क्योंकि हमलावरों को सर्वर डेटाबेस से महत्वपूर्ण जानकारी तक पहुंच मिल सकती है। अपने वेब एप्लिकेशन में SQL इंजेक्शन प्रवेश बिंदुओं की जांच करने के लिए, अपने कोड आधार से कोड का पता लगाएं जहां कुछ उपयोगकर्ता इनपुटों को स्वीकार करके डेटाबेस पर प्रत्यक्ष MySQL प्रश्नों को निष्पादित किया जाता है।

SQL इंजेक्शन परीक्षण ब्रैकेट, कॉमास और उद्धरण चिह्नों के लिए किया जा सकता है।

पासवर्ड क्रैकिंग

डेटाबेस सिस्टम टेस्टिंग करते समय यह सबसे महत्वपूर्ण जाँच है। महत्वपूर्ण जानकारी तक पहुंचने के लिए, हैकर्स पासवर्ड-क्रैकिंग टूल का उपयोग कर सकते हैं या एक सामान्य उपयोगकर्ता नाम / पासवर्ड का अनुमान लगा सकते हैं। ये सामान्य पासवर्ड इंटरनेट पर आसानी से उपलब्ध हैं और पासवर्ड क्रैकिंग टूल भी स्वतंत्र रूप से मौजूद हैं।

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

डेटाबेस सिस्टम का सिक्योरिटी ऑडिट

एक सुरक्षा ऑडिट एक नियमित समय अंतराल पर कंपनी की सुरक्षा नीतियों का मूल्यांकन करने की एक प्रक्रिया है, यह निर्धारित करने के लिए कि आवश्यक मानकों का पालन किया जाता है या नहीं। सुरक्षा नीति को परिभाषित करने के लिए व्यावसायिक आवश्यकता के अनुसार विभिन्न सुरक्षा मानकों का पालन किया जा सकता है और फिर उन मानकों के विरुद्ध निर्धारित नीतियों का मूल्यांकन किया जा सकता है।

सबसे सामान्य सुरक्षा मानकों का उदाहरण आईएसओ 27001, बीएस 15999, आदि हैं।

डेटाबेस सुरक्षा परीक्षण उपकरण

बाजार में विभिन्न सिस्टम परीक्षण उपकरण उपलब्ध हैं, जिनका उपयोग ओएस और एप्लिकेशन चेक का परीक्षण करने के लिए किया जा सकता है। सबसे आम उपकरणों में से कुछ नीचे चर्चा की गई है।

जेड हमला प्रॉक्सी

यह वेब अनुप्रयोगों में भेद्यता खोजने के लिए एक पैठ-परीक्षण उपकरण है। यह लोगों द्वारा सुरक्षा अनुभव की एक विस्तृत श्रृंखला के साथ उपयोग करने के लिए डिज़ाइन किया गया है और जैसे कि डेवलपर्स और कार्यात्मक परीक्षकों के लिए आदर्श है जो प्रवेश परीक्षण के लिए नए हैं। यह आमतौर पर विंडोज, लिनक्स, मैक ओएस के लिए उपयोग किया जाता है।

Paros

सर्वर और क्लाइंट के बीच सभी HTTP और HTTPS डेटा, जिसमें कुकीज़ और फॉर्म फ़ील्ड शामिल हैं, इन स्कैनर का उपयोग करके इंटरसेप्ट और संशोधित किया जा सकता है। इसका उपयोग क्रॉस-प्लेटफॉर्म, जावा JRE / JDK 1.4.2 या इसके बाद के संस्करण के लिए किया जाता है।

सोशल इंजीनियर टूलकिट

यह एक खुला स्रोत उपकरण है और मानव तत्वों पर सिस्टम तत्व के बजाय हमला किया जाता है। यह आपको हमले कोड वाले ईमेल, जावा एप्लेट आदि भेजने में सक्षम बनाता है। यह लिनक्स, एप्पल मैक ओएस एक्स और माइक्रोसॉफ्ट विंडोज के लिए पसंद किया जाता है।

Skipfish

इस उपकरण का उपयोग कमजोरियों के लिए उनकी साइटों को स्कैन करने के लिए किया जाता है। उपकरण द्वारा उत्पन्न रिपोर्टें पेशेवर वेब अनुप्रयोग सुरक्षा आकलन के लिए एक आधार के रूप में सेवा करने के लिए होती हैं। यह लिनक्स, फ्रीबीएसडी, मैकओएस एक्स और विंडोज के लिए पसंद किया जाता है।

वेगा

यह एक खुला स्रोत है, मल्टीप्लायर वेब सुरक्षा उपकरण जिसका उपयोग SQL इंजेक्शन, क्रॉस-साइट स्क्रिप्टिंग (XSS), और वेब अनुप्रयोगों में अन्य कमजोरियों के उदाहरणों को खोजने के लिए किया जाता है। यह जावा, लिनक्स और विंडोज के लिए पसंद किया जाता है।

Wapiti

Wapiti एक खुला स्रोत और वेब-आधारित उपकरण है जो वेब एप्लिकेशन के वेब पेजों को स्कैन करता है और स्क्रिप्ट और प्रपत्रों की जांच करता है जहां यह डेटा इंजेक्ट कर सकता है। यह पायथन के साथ बनाया गया है और फ़ाइल हैंडलिंग त्रुटियों, डेटाबेस, XSS, LDAP और CRLF इंजेक्शन, कमांड निष्पादन का पता लगा सकता है।

वेब स्कारब

यह जावा में लिखा गया है और इसका उपयोग उन अनुप्रयोगों के विश्लेषण के लिए किया जाता है जो HTTP / HTTPS प्रोटोकॉल के माध्यम से संवाद करते हैं। यह उपकरण मुख्य रूप से डेवलपर्स के लिए डिज़ाइन किया गया है जो स्वयं कोड लिख सकते हैं। यह उपकरण OS निर्भर नहीं है।

डेटाबेस परीक्षण सफलतापूर्वक करने के लिए, एक परीक्षक को सभी स्रोतों से आवश्यकताओं को इकट्ठा करना चाहिए, जैसे तकनीकी और कार्यात्मक आवश्यकताएं। ऐसी संभावना है कि कुछ आवश्यकताएं उच्च स्तर पर हैं, इसलिए उन आवश्यकताओं को छोटे भागों में विभाजित करने की आवश्यकता है। परीक्षण डेटाबेस एक जटिल कार्य है और इस परीक्षण को करते समय परीक्षकों को कई चुनौतियों का सामना करना पड़ता है। सबसे आम डेटाबेस परीक्षण चुनौतियां हैं -

परीक्षण का दायरा बहुत बड़ा है

एक परीक्षक को डेटाबेस परीक्षण में परीक्षण वस्तुओं की पहचान करने की आवश्यकता होती है अन्यथा उसे इस बात की स्पष्ट समझ नहीं हो सकती है कि वह क्या परीक्षण करेगा और क्या परीक्षण नहीं करेगा। इसलिए, यदि आप आवश्यकता पर स्पष्ट हैं, तो आप डेटाबेस में कई बार बेकार वस्तुओं का परीक्षण कर सकते हैं।

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

चूंकि डेटाबेस का आकार बहुत बड़ा है, इसलिए यह उन वस्तुओं का पता लगाने के लिए एक बड़ी चुनौती बन जाता है जिनका परीक्षण किया जाना है और जिन्हें छोड़ा जाना है।

स्केल्ड-डाउन परीक्षण डेटाबेस

आम तौर पर परीक्षकों को परीक्षण करने के लिए विकास डेटाबेस की एक प्रति प्रदान की जाती है। उस डेटाबेस में केवल कम डेटा होता है, जो एप्लिकेशन को चलाने के लिए पर्याप्त होता है। इसलिए विकास, मंचन और साथ ही उत्पादन डेटाबेस प्रणाली का परीक्षण करने की आवश्यकता है।

डेटाबेस संरचना में परिवर्तन

यह डीबी परीक्षण में आम चुनौतियों में से एक है। कभी-कभी, ऐसा होता है कि आप एक परीक्षण को डिजाइन या निष्पादित करते हैं, और उस समय डेटाबेस संरचना को बदल दिया गया है। यह आवश्यक है कि आपको परीक्षण के दौरान डेटाबेस में किए गए परिवर्तनों के बारे में पता होना चाहिए।

एक बार जब डेटाबेस संरचना बदल जाती है, तो आपको परिवर्तनों के प्रभाव का विश्लेषण करना चाहिए और परीक्षणों को संशोधित करना चाहिए। इसके अलावा, यदि कई उपयोगकर्ता परीक्षण डेटाबेस का उपयोग करते हैं, तो आप परीक्षण परिणामों के बारे में सुनिश्चित नहीं होंगे, इसलिए आपको यह सुनिश्चित करना चाहिए कि परीक्षण डेटाबेस का उपयोग केवल परीक्षण उद्देश्य के लिए किया जाता है।

DB परीक्षण में एक और चुनौती यह है कि आप एक ही समय में कई परीक्षण चलाते हैं। आपको कम से कम प्रदर्शन परीक्षणों के लिए एक बार में एक परीक्षण चलाना चाहिए। आप नहीं चाहते हैं कि आपका डेटाबेस कई कार्यों और अंडर-रिपोर्टिंग प्रदर्शन कर रहा है।

जटिल परीक्षण की योजना

डेटाबेस संरचना सामान्य रूप से जटिल है और इसमें बहुत बड़ा डेटा है, इसलिए संभावना है कि आप बार-बार अपूर्ण या समान परीक्षणों को निष्पादित कर रहे हैं। इसलिए एक परीक्षण योजना बनाने और तदनुसार प्रगति और नियमित रूप से जांच करने की आवश्यकता है।

एसक्यूएल की अच्छी समझ

डेटाबेस का परीक्षण करने के लिए, आपके पास SQL ​​प्रश्नों और आवश्यक डेटाबेस प्रबंधन टूल का अच्छा ज्ञान होना चाहिए।

डेटाबेस परीक्षण में डेटा वैधता, डेटा अखंडता परीक्षण, डेटाबेस से संबंधित प्रदर्शन की जांच और प्रक्रिया के परीक्षण, डेटाबेस में ट्रिगर और फ़ंक्शन शामिल हैं।

डेटाबेस परीक्षण क्यों किया जाता है इसके कई कारण हैं। डेटाबेस पर डेटा अखंडता, सत्यापन और डेटा स्थिरता जांच करने की आवश्यकता है क्योंकि बैकएंड सिस्टम डेटा को संग्रहीत करने के लिए जिम्मेदार है और कई उद्देश्य से एक्सेस किया जाता है।

डेटाबेस परीक्षण करने की आवश्यकता के कुछ सामान्य कारण इस प्रकार हैं -

  • डेटाबेस बैकएंड पर कॉल की जटिलता को कम करने के लिए, डेवलपर्स इसके उपयोग को बढ़ाते हैं View तथा Stored प्रक्रिया।

  • इन Stored प्रक्रियाओं और Viewsग्राहक विवरण (नाम, संपर्क जानकारी, आदि) डालने और बिक्री डेटा जैसे महत्वपूर्ण कार्य शामिल हैं। इन कार्यों को कई स्तरों पर जांचने की आवश्यकता है।

  • फ्रंट-एंड पर किया गया ब्लैक बॉक्स परीक्षण महत्वपूर्ण है, लेकिन इससे समस्या को अलग करना मुश्किल हो जाता है। बैकएंड सिस्टम पर परीक्षण करने से डेटा की मजबूती बढ़ जाती है। यही कारण है कि डेटाबेस परीक्षण बैक एंड सिस्टम पर किया जाता है।

  • एक डेटाबेस में, डेटा कई अनुप्रयोगों से आता है और एक संभावना है कि डेटाबेस में हानिकारक या गलत डेटा संग्रहीत है। इसलिए, डेटाबेस घटकों को नियमित रूप से जांचने की आवश्यकता है। इसके अलावा, डेटा अखंडता और स्थिरता को नियमित रूप से जांचना चाहिए।

डेटाबेस परीक्षण करते समय आपको जिन चरणों का पालन करने की आवश्यकता है वे इस प्रकार हैं -

  • डेटाबेस में मौजूद डेटा को सत्यापित किया जाना चाहिए।
  • सत्यापित करें कि क्या बाधाएँ बनी हुई हैं।
  • प्रक्रियाओं के प्रदर्शन और ट्रिगर्स के निष्पादन की जाँच की जानी चाहिए।
  • रोल बैक और लेन-देन की जांच होनी चाहिए।

एक डेटाबेस के कार्य और संरचना के आधार पर, डीबी परीक्षण को निम्नलिखित श्रेणियों में वर्गीकृत किया जा सकता है -

  • Structural Database testing - यह तालिका और स्तंभ परीक्षण, स्कीमा परीक्षण, संग्रहीत कार्यविधियाँ और विचार परीक्षण, ट्रिगर जाँच इत्यादि से संबंधित है।

  • Functional Testing- इसमें उपयोगकर्ता के दृष्टिकोण से डेटाबेस की कार्यक्षमता की जाँच करना शामिल है। अधिकांश सामान्य प्रकार के कार्यात्मक परीक्षण व्हाइट बॉक्स और ब्लैक बॉक्स परीक्षण हैं।

  • Nonfunctional Testing - इसमें लोड टेस्टिंग, डेटाबेस में रिस्क टेस्टिंग, स्ट्रेस टेस्टिंग, मिनिमम सिस्टम की आवश्यकता, और डेटाबेस के wot प्रदर्शन को शामिल किया गया है।

संग्रहीत कार्यविधियाँ परीक्षण करने के लिए उपयोग किए जाने वाले सबसे आम उपकरण LINQ, SP टेस्ट उपकरण, आदि हैं।

कुछ तार्किक तरीके से दो या अधिक तालिकाओं को जोड़ने के लिए जोड़ों का उपयोग किया जाता है। सामान्य प्रकार के जुड़ने में शामिल हैं: इनर जॉइन, नॉन-इक्विजॉइन, आउटर जॉइन, सेल्फ-जॉइन और क्रॉस जॉइन।

आप एक ही तालिका में शामिल हो सकते हैं। इस स्थिति में, आप एक ही तालिका का दो बार उपयोग कर रहे हैं।

Step 1 - डेटाबेस से कनेक्ट करें

db_connect(query1 DRIVER {drivername};SERVER server_name;UID uidname;
   PWD password;DBQ database_name );

Step 2 - डेटाबेस की क्वेरी निष्पादित करें -

db_excecute_query (write the required query that is to execute); Specify the appropriate condition

Step 3 - डेटाबेस कनेक्शन का उपयोग करके डिस्कनेक्ट करें

db_disconnect(query);

आउटपुट डेटाबेस चौकियों का उपयोग करते हुए, SQL मैन्युअल क्वेरी विकल्प का चयन करना होगा। यहां, चयन क्वेरी लिखी जा सकती है।

सबसे पहले, संग्रहीत प्रक्रिया की आवश्यकता की जांच करें। अगला चरण यह जांचना है कि क्या संग्रहीत कार्यविधि में उल्लिखित तालिकाओं की तुलना में इंडेक्स, जॉइन, डिलीट, अपडेट सही हैं।

अगला, निम्नलिखित कार्य करें -

  • कॉलिंग प्रक्रिया का नाम, कॉलिंग पैरामीटर और इनपुट पैरामीटर के विभिन्न सेट के लिए अपेक्षित प्रतिक्रियाएं मान्य करें।

  • TOAD या MySQL या क्वेरी विश्लेषक के साथ प्रक्रिया निष्पादित करें।

  • विभिन्न मापदंडों को भेजकर उपलब्ध प्रक्रियाओं को फिर से निष्पादित करें, और अपेक्षित मूल्यों के खिलाफ परिणामों की जांच करें।

  • इस प्रक्रिया को छोड़कर, WinRunner के साथ परीक्षणों को स्वचालित करें।

परीक्षक को EXEC कमांड का उपयोग करके डेटाबेस में संग्रहीत प्रक्रिया को कॉल करना चाहिए। यदि किसी भी पैरामीटर की आवश्यकता होती है, तो उन्हें पारित किया जाना चाहिए। संग्रहीत प्रक्रिया निष्पादित की जाती है या नहीं, इसकी पुष्टि करने के लिए मापदंडों के विभिन्न मूल्यों को पारित किया जाना चाहिए। इस आदेश को कॉल करने पर इसे डेटाबेस की प्रकृति और व्यवहार की जांच और सत्यापन करना होगा।

Example - यदि संग्रहीत कार्यविधि को किसी तालिका को आबाद करने के लिए लिखा जाता है, तो तालिका मानों की जाँच की जानी चाहिए।

हमारे पास तीन प्रकार के SQL स्टेटमेंट हैं -

  • डेटा हेरफेर भाषा (DML)
  • डेटा परिभाषा भाषा (DDL)
  • डेटा नियंत्रण भाषा (DCL)

डेटाबेस संरचना या स्कीमा को परिभाषित करने के लिए DDL स्टेटमेंट का उपयोग किया जाता है। कुछ उदाहरण -

  • CREATE - डेटाबेस में ऑब्जेक्ट बनाने के लिए

  • ALTER - डेटाबेस की संरचना को बदल देता है

  • DROP - डेटाबेस से वस्तुओं को हटा दें

किसी SQL कथन में शर्तों को निर्दिष्ट करने और किसी कथन में कई स्थितियों के लिए संयोजन के रूप में कार्य करने के लिए ऑपरेटर्स का उपयोग किया जाता है।

  • अंकगणितीय आपरेटर
  • तुलनात्मक / रिलेशनल ऑपरेटर्स
  • लॉजिकल ऑपरेटर्स
  • ऑपरेटर सेट करें
  • संचालक स्थितियों को नकारते थे

संघ का उपयोग दो या अधिक चयनित कथनों के परिणामों को संयोजित करने के लिए किया जाता है। हालाँकि यह डुप्लिकेट पंक्तियों को समाप्त कर देगा। यूनियन एक सेट ऑपरेटर है।

Unionका उपयोग दो या दो से अधिक चयन विवरणों को संयोजित करने के लिए किया जाता है। हालाँकि यह डुप्लिकेट पंक्तियों को समाप्त कर देगा

Union All ऑपरेशन यूनियन के समान है, लेकिन यह डुप्लिकेट पंक्तियों को भी दिखाता है।

डेटाबेस की वफ़ादारी को बनाए रखने के लिए ट्रिगर का उपयोग किया जाता है। जाँचने के लिए ट्रिगर निकाल दिया गया है या नहीं, आप ऑडिट लॉग में देख सकते हैं।

ट्रिगर मांग पर लागू नहीं किया जा सकता है। जब कोई संबद्ध क्रिया (सम्मिलित करें, हटाएं और अपडेट करें) तब मेज पर होती हैं, जिस पर उन्हें परिभाषित किया जाता है। ट्रिगर का उपयोग व्यावसायिक नियमों, ऑडिटिंग और संदर्भात्मक अखंडता जांच के लिए भी किया जाता है।

सबसे पहले, कार्यात्मक आवश्यकता प्राप्त करें। फिर, तालिका संरचना, जॉइन, कर्सर और ट्रिगर, संग्रहीत प्रक्रिया और अन्य मापदंडों को समझें। इसके बाद, आप इन ऑब्जेक्ट्स के इनपुट के रूप में विभिन्न मानों के साथ एक टेस्ट-केस लिख सकते हैं।

DB परीक्षण में बैक-एंड घटकों का परीक्षण शामिल है जो उपयोगकर्ताओं को दिखाई नहीं देते हैं। इसमें डेटाबेस घटक और DBMS सिस्टम जैसे MySQL और Oracle शामिल हैं।

फ़्रंट-एंड टेस्टिंग में किसी एप्लिकेशन और उसके घटकों जैसे फ़ंक्शंस, ग्राफ़, मेनू, रिपोर्ट, आदि की कार्यक्षमता की जाँच करना शामिल है। इन घटकों को VB.net, C #, डेल्फी, आदि जैसे फ्रंट-एंड डेवलपमेंट टूल्स का उपयोग करके बनाया जाता है।

डेटाबेस परीक्षण करने की प्रक्रिया अन्य अनुप्रयोगों के परीक्षण के समान है। DB परीक्षण को निम्नलिखित प्रमुख प्रक्रियाओं के साथ वर्णित किया जा सकता है -

  • पर्यावरण की स्थापना
  • एक परीक्षण चलाएं
  • परीक्षा परिणाम की जाँच करें
  • अपेक्षित परिणाम के अनुसार मान्य
  • संबंधित हितधारकों के निष्कर्षों की रिपोर्ट करें

परीक्षण मामलों को विकसित करने के लिए विभिन्न एसक्यूएल बयानों का उपयोग किया जाता है। सबसे आम एसक्यूएल स्टेटमेंट जो डीबी टेस्टिंग करने के लिए उपयोग किया जाता है वह सेलेक्ट स्टेटमेंट है। इसके अलावा विभिन्न डीडीएल, डीएमएल, डीसीएल स्टेटमेंट का भी उपयोग किया जा सकता है।

Example - बनाएं, डालें, चुनें, अपडेट करें आदि।

एक दृश्य एक तालिका है जो वास्तव में अपने आप में मौजूद नहीं है, बल्कि इसके बजाय एक या अधिक आधार तालिका से ली गई है। दूसरे शब्दों में, कोई संग्रहीत फ़ाइल नहीं है जो प्रत्यक्ष दृश्य का प्रतिनिधित्व करती है इसके बजाय दृश्य की परिभाषा डेटा शब्दकोश में संग्रहीत की जाती है।

बेस टेबल का विकास और पुनर्गठन विचारों में परिलक्षित नहीं होता है। इस प्रकार यह दृश्य उपयोगकर्ताओं को डेटाबेस में बदलाव से प्रेरित कर सकता है। इसलिए तार्किक डेटा स्वतंत्रता के लिए जिम्मेदार है।

यह उपयोगकर्ता के विचारों और उनके मानचित्रण को वैचारिक स्कीमा के लिए निर्दिष्ट करता है।

यह किसी भी जानकारी को खोए बिना एक तालिका को कई तालिकाओं में विघटित करने की एक प्रक्रिया है। निम्नलिखित लक्ष्यों को प्राप्त करने के लिए सामान्यीकरण किया जाता है -

  • अतिरेक को कम करने के लिए।
  • सम्मिलन, विलोपन को कम करने और विसंगतियों को अद्यतन करने के लिए।

इंडेक्सिंग यह निर्धारित करने की तकनीक है कि विशिष्ट डेटा कितनी जल्दी मिल सकता है। इसका उपयोग क्वेरी प्रदर्शन अनुकूलन के लिए किया जाता है। अनुक्रमण निम्न प्रकार के हो सकते हैं -

  • बाइनरी सर्च स्टाइल इंडेक्सिंग
  • बी-ट्री इंडेक्सिंग
  • उल्टे सूची अनुक्रमण
  • स्मृति निवासी तालिका
  • तालिका अनुक्रमण

SQL एक संरचित क्वेरी भाषा है जिसे विशेष रूप से सामान्यीकृत रिलेशनल डेटाबेस संरचनाओं पर डेटा एक्सेस संचालन के लिए डिज़ाइन किया गया है।

SQL और अन्य पारंपरिक प्रोग्रामिंग भाषाओं के बीच प्राथमिक अंतर यह है कि SQL स्टेटमेंट निर्दिष्ट करते हैं कि डेटा ऑपरेशन कैसे किया जाना चाहिए, बजाय उन्हें कैसे निष्पादित किया जाए।

उपयोगकर्ता परिभाषित ऑपरेशन करने के लिए संग्रहीत प्रक्रियाओं का उपयोग किया जाता है। एक संग्रहीत कार्यविधि में कंपाउंड SQL कथनों का एक सेट हो सकता है। एक संग्रहीत कार्यविधि SQL कमांड निष्पादित करती है और क्लाइंट को परिणाम लौटाती है।

पीएल / एसक्यूएल सभी डेटाबेस सूचनाओं को बयानों तक पहुँचने के लिए कर्सर का उपयोग करता है। भाषा दो प्रकार के अभिशापों का उपयोग करने का समर्थन करती है - निहित और स्पष्ट।

Cold Backup- कोल्ड बैक को डेटाबेस फाइल, रीडो लॉग और कंट्रोल फाइल के बैक अप लेने के रूप में जाना जाता है, जब इंस्टेंस बंद हो जाता है। यह एक फाइल कॉपी है, आमतौर पर डिस्क से सीधे टेप तक। सुसंगत प्रतिलिपि की गारंटी देने के लिए आपको उदाहरण बंद करना होगा।

यदि एक ठंडा बैकअप किया जाता है, तो डेटा फ़ाइल हानि की स्थिति में उपलब्ध एकमात्र विकल्प नवीनतम बैकअप से सभी फ़ाइलों को पुनर्स्थापित कर रहा है। अंतिम बैकअप खो जाने के बाद किए गए सभी परिवर्तन।

Hot Backup- कुछ डेटाबेस फाइलों की बैकअप कॉपी बनाते समय बंद नहीं कर सकते, इसलिए कोल्ड बैकअप एक उपलब्ध विकल्प नहीं है। इस प्रकार के डेटाबेस के लिए हम हॉट बैकअप का उपयोग करते हैं।

एसक्यूएल सबक्वेरी एक ही समय में दो या अधिक तालिकाओं को क्वेरी करने का एक साधन है। उपश्रेणी स्वयं एक SQL SELECT स्टेटमेंट है, जिसमें दूसरे SQL SELECT स्टेटमेंट के WHERE क्लॉज में समाहित किया गया है, और कोष्ठक में संलग्न होकर अलग किया गया है। कुछ उपश्रेणियों में समान SQL ज्वाइन संरचनाएँ होती हैं, लेकिन सहसंबंधित उपकुंजियों को जोड़ से डुप्लिकेट नहीं किया जा सकता है

ऐसे मामले में, आपको निम्नलिखित पहलुओं का परीक्षण करने की आवश्यकता है -

  • बहुविकल्पी निर्भरता
  • क्रियात्मक निर्भरता
  • उम्मीदवार कुंजी
  • प्राथमिक कुंजी
  • विदेशी कुंजी

आप डेटाबेस में जा सकते हैं और एक प्रासंगिक SQL क्वेरी चला सकते हैं। WinRunner में, आप डेटाबेस चेकपॉइंट फ़ंक्शन का उपयोग कर सकते हैं। यदि एप्लिकेशन दृश्य फ़ंक्शन प्रदान करता है, तो आप फ्रंट-एंड से उसी को सत्यापित कर सकते हैं।

डेटा-चालित परीक्षण को एक स्वचालन परीक्षण प्रक्रिया के रूप में परिभाषित किया जाता है, जहाँ एप्लिकेशन को कई परीक्षण डेटा के साथ परीक्षण किया जाएगा। यह रिटायर होने की तुलना में सरल और आसान है जहां परीक्षक सिर्फ सिस्टम के सामने बैठते हैं और फ्रंट-एंड इंटरफ़ेस से मैन्युअल रूप से अलग-अलग नए इनपुट मान दर्ज करते हैं।

एक बार जब आप परीक्षण-मामलों को निष्पादित करते हैं और उन दोषों को ढूंढते हैं जो पहले से ही पता लगाए गए हैं और तय किए गए हैं। मूल दोष की पुष्टि करने के लिए अलग-अलग इनपुट मूल्यों के साथ एक ही परीक्षण का पुनः निष्पादन सफलतापूर्वक हटा दिया गया है।

रिटायरिंग को एक छोटे अंतर के साथ डेटा ड्रिवन टेस्टिंग भी कहा जाता है -

  • Retesting - यह एक मैनुअल परीक्षण प्रक्रिया है, जबकि डेटा के पूरे नए सेट के साथ आवेदन परीक्षण किया जाता है।

  • Data-driven Testing- यह एक स्वचालन परीक्षण प्रक्रिया है जहां आवेदन को कई परीक्षण डेटा के साथ परीक्षण किया जाएगा। यह रिटायर होने की तुलना में सरल और आसान है जहां परीक्षक सिर्फ सिस्टम के सामने बैठते हैं और फ्रंट-एंड इंटरफ़ेस से मैन्युअल रूप से अलग-अलग नए इनपुट मान दर्ज करते हैं।

डेटा संचालित परीक्षण के चार प्रकार हैं -

  • कीबोर्ड के माध्यम से डायनामिक टेस्ट डेटा सबमिशन
  • .Txt, .doc फ्लैट फ़ाइलों के माध्यम से डेटा चालित टेस्ट
  • फ्रंट-एंड ऑब्जेक्ट्स के माध्यम से डेटा ड्रिवेन टेस्ट
  • एक्सेल शीट के माध्यम से डेटा चालित टेस्ट

प्रदर्शन परीक्षण एक सॉफ्टवेयर परीक्षण तकनीक है, यह निर्धारित करने के लिए कि एक सिस्टम एक भारी कार्यभार के तहत गति, संवेदनशीलता और स्थिरता के संदर्भ में कैसे प्रदर्शन करता है।

डेटाबेस रिकवरी परीक्षण करते समय निम्नलिखित मुख्य बिंदुओं पर विचार किया जाना चाहिए -

  • डेटाबेस सिस्टम में परिवर्तन या संशोधन होने पर समय लगता है।

  • वह अवधि जिसके द्वारा आप अपनी पुनर्प्राप्ति योजना का संचालन करना चाहते हैं।

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

निम्नलिखित उपकरण परीक्षण डेटा उत्पन्न करने के लिए उपयोग किए जाते हैं -

  • डेटा फैक्टरी
  • DTM डेटा जेनरेटर
  • टर्बो डेटा

दो प्रकार के बैकअप हैं जिनका उपयोग किया जा सकता है -

  • Physical Backups- भौतिक बैकअप में ओएस की उपयोगिताओं का उपयोग करके वेरिटास नेट बैक, आईबीएम टिवोली प्रबंधक या उपयोगकर्ता प्रबंधक बैकअप जैसे 3 आरडी पार्टी बैकअप टूल का उपयोग करना शामिल है।

  • Logical Backups - डेटाबेस के लॉजिकल बैकअप में लॉजिकल ऑब्जेक्ट्स जैसे टेबल, इंडेक्स, प्रोसेस आदि को वापस लेना शामिल है।

डेटा बैकअप लेने के लिए एक सामान्य टूल ओरेकल रिकवरी मैनेजर (RMAN) है जो डेटाबेस बैकअप लेने के लिए ओरेकल यूटिलिटी है।

डेटाबेस पुनर्प्राप्ति परीक्षण में निम्नलिखित क्रियाएं की जाती हैं -

  • डेटाबेस सिस्टम का परीक्षण
  • SQL फ़ाइलों का परीक्षण
  • आंशिक फ़ाइलों का परीक्षण
  • डेटा बैकअप का परीक्षण
  • बैकअप टूल का परीक्षण
  • परीक्षण लॉग बैकअप

डेटाबेस सुरक्षा परीक्षण सुरक्षा तंत्र में लूप होल्स को खोजने के लिए और डेटाबेस सिस्टम की कमजोरियों या कमजोरियों को खोजने के लिए किया जाता है।

डेटाबेस सुरक्षा परीक्षण निम्नलिखित पहलुओं की जांच करने के लिए किया जाता है -

  • Authentication
  • Authorization
  • Confidentiality
  • Availability
  • Integrity
  • Resilience

SQL इंजेक्शन खतरा एक डेटाबेस सिस्टम में सबसे आम प्रकार का हमला है जहाँ डेटाबेस सिस्टम में दुर्भावनापूर्ण SQL स्टेटमेंट डाले जाते हैं और डेटाबेस सिस्टम से महत्वपूर्ण जानकारी प्राप्त करने के लिए इसे निष्पादित किया जाता है। यह हमला उपयोगकर्ता अनुप्रयोगों के कार्यान्वयन में खामियों का फायदा उठाता है। इसे रोकने के लिए उपयोगकर्ता इनपुट फ़ील्ड को सावधानीपूर्वक संभाला जाना चाहिए।

डेटाबेस सुरक्षा परीक्षण करने के लिए निम्नलिखित टूल का उपयोग किया जा सकता है: जेड अटैक प्रॉक्सी, पारोस, सोशल इंजीनियर टूलकिट, स्किपफिश, वेगा, Wapiti और ​​वेब स्कारब।

डेटाबेस परीक्षण करते समय आम चुनौतियों का सामना इस प्रकार है -

  • परीक्षण का दायरा बहुत बड़ा है
  • स्केल्ड-डाउन परीक्षण डेटाबेस
  • डेटाबेस संरचना में परिवर्तन
  • जटिल परीक्षण योजनाएँ
  • एसक्यूएल की अच्छी समझ