हटाएं (एसक्यूएल)
डेटाबेस स्ट्रक्चर्ड क्वेरी लैंग्वेज (एसक्यूएल) में, DELETE स्टेटमेंट तालिका (डेटाबेस) से एक या एक से अधिक रिकॉर्ड्स को हटा देता है। समुच्चय उपसमुच्चय को एक शर्त का उपयोग करके विलोपन के लिए परिभाषित किया जा सकता है, अन्यथा सभी रिकॉर्ड हटा दिए जाते हैं।[1] कुछ डेटाबेस#डेटाबेस प्रबंधन प्रणाली (डीबीएमएस), जैसे MySQL, समुच्चयDELETE कथन के साथ कई तालिकाओं से पंक्तियों को हटाने की अनुमति देता है (इसे कभी-कभी मल्टी-टेबल DELETE कहा जाता है)।
उदाहरण
तालिका पाई से पंक्ति (डेटाबेस) हटाएं जहां कॉलम (डेटाबेस) स्वाद लेमन मेरिंग्यू के बराबर है:
DELETE FROM pies
WHERE flavor='Lemon Meringue';
यदि ऊँचाई का मान 80 से कम है, तो पेड़ों में पंक्तियों को हटा दें।
DELETE FROM trees
WHERE height < 80;
mytable से सभी पंक्तियां हटाएं:
DELETE FROM mytable;
mytable से पंक्तियाँ जहाँ स्थिति में सबक्वेरी का उपयोग करके हटाएं:
<वाक्यविन्यास लैंग = एसक्यूएल> मायटेबल से हटाएं
जहां आईडी में ( आईडी चुनें mytable2 से );
</वाक्यविन्यास हाइलाइट>
मानों की सूची का उपयोग करके mytable से पंक्तियां हटाएं: <वाक्यविन्यास लैंग = एसक्यूएल> मायटेबल से हटाएं
जहां आईडी में ( मान1, मान2, मान3, मान4, value5 );
</वाक्यविन्यास हाइलाइट>
संबंधित तालिकाओं के साथ उदाहरण
मान लीजिए कि समुच्चयसाधारण डेटाबेस है जो लोगों और पतों को सूचीबद्ध करता है। समुच्चयविशेष पते पर एक से अधिक व्यक्ति रह सकते हैं और एक व्यक्ति एक से अधिक पते पर रह सकता है (यह अनेक-से-अनेक (डेटा मॉडल)|अनेक-से-अनेक संबंध का समुच्चयउदाहरण है)। निम्नलिखित डेटा के साथ डेटाबेस में केवल तीन टेबल, व्यक्ति, पता और पीए हैं:
|
|
|
पीए टेबल व्यक्ति और एड्रेस टेबल से संबंधित है, यह दर्शाता है कि जो, बॉब और ऐन सभी 2001 मेन स्ट्रीट पर रहते हैं, लेकिन जो पिको बुलेवार्ड पर भी निवास करता है।
डेटाबेस से जो को हटाने के लिए, दो विलोपन निष्पादित किए जाने चाहिए: <वाक्यविन्यास लैंग = एसक्यूएल>
व्यक्ति से हटाएं जहां पीआईडी=1; पा से हटाएं जहां पिड = 1;
</वाक्यविन्यास हाइलाइट> संदर्भित सत्यनिष्ठा बनाए रखने के लिए, जो के रिकॉर्ड को व्यक्ति और पिता दोनों से हटा दिया जाना चाहिए। अलग-अलग संबंधपरक डेटाबेस प्रबंधन प्रणालियों में अखंडता को बनाए रखने के तरीके अलग-अलग हो सकते हैं।[citation needed] यह हो सकता है कि केवल तीन तालिकाओं से परे, डेटाबेस को समुच्चयट्रिगर के साथ भी स्थापित किया गया हो ताकि जब भी किसी व्यक्ति से कोई पंक्ति हटाई जाए तो किसी भी लिंक की गई पंक्तियों को पा से हटा दिया जाएगा। फिर पहला कथन: <वाक्यविन्यास लैंग = एसक्यूएल>
व्यक्ति से हटाएं जहां पीआईडी=1;
</वाक्यविन्यास हाइलाइट> स्वचालित रूप से दूसरे को ट्रिगर करेगा: <वाक्यविन्यास लैंग = एसक्यूएल>
पा से हटाएं जहां पिड = 1;
</वाक्यविन्यास हाइलाइट>
विशेषताएं
- यह समुच्चयडीएमएल (डेटा मैनीपुलेशन लैंग्वेज) कमांड है, इसलिए इस कमांड के लिए निम्नलिखित कमांड का उपयोग किया जाता है: COMMIT और ROLLBACK
- तालिका से सभी या कुछ रिकॉर्ड हटा देता है, आप WHERE क्लॉज का उपयोग करके हटाए जाने वाले रिकॉर्ड को सीमित कर सकते हैं
- तालिका में (टेबलस्पेस में) डेटा द्वारा कब्जा कर लिया गया स्थान खाली नहीं करता है
- तालिका को निर्दिष्ट SEQUENCE मान को रीसेट नहीं करता है
- DELETE, TRUNCATE की तुलना में बहुत धीमी गति से काम करता है
- आप ROLLBACK कमांड का उपयोग करके रिकॉर्ड हटाने की कार्रवाई को पूर्ववत कर सकते हैं
- DELETE के लिए समुच्चयसाझा टेबल लॉक की आवश्यकता होती है
- आग लगा देता है
- DELETE का उपयोग डेटाबेस लिंक के मामले में किया जा सकता है
- DELETE हटाए गए रिकॉर्ड की संख्या लौटाता है
- लेन-देन लॉग - DELETE को रिकॉर्ड पढ़ने, बाधाओं की जांच करने, अपडेट ब्लॉक, अपडेट इंडेक्स और फिर से / पूर्ववत करने की आवश्यकता है। इस सब में समय लगता है, इसलिए TRUNCATE की तुलना में इसमें अधिक समय लगता है
- निष्पादन के दौरान प्रदर्शन को कम करता है - तालिका में प्रत्येक रिकॉर्ड को हटाने के लिए बंद कर दिया गया है
- DELETE TRUNCATE स्टेटमेंट की तुलना में अधिक ट्रांजैक्शन स्पेस का उपयोग करता है
- DELETE का उपयोग अनुक्रमित दृश्यों के साथ किया जा सकता है
- DELETE कम मात्रा में फिर से करें और बड़ी मात्रा में पूर्ववत करें
- DELETE ऑपरेशन अनुपयोगी इंडेक्स को फिर से प्रयोग करने योग्य नहीं बनाता है
संबंधित आदेश
तालिका से सभी पंक्तियों को हटाने में बहुत समय लग सकता है। कुछ डीबीएमएस[clarification needed] समुच्चयट्रंकेट (एसक्यूएल) कमांड की पेशकश करें जो बहुत तेजी से काम करता है, क्योंकि यह केवल मेटाडेटा को बदलता है और आमतौर पर बाधाओं को लागू करने या ट्रिगर्स को सक्रिय करने में समय व्यतीत नहीं करता है।
DELETE केवल पंक्तियों को हटाता है। किसी तालिका को पूरी तरह से हटाने के लिए ड्रॉप (एसक्यूएल) कमांड का उपयोग किया जा सकता है।
संदर्भ
- ↑ "SQL Delete Statement". w3schools.com.
बाहरी संबंध
- Truncate vs Delete SQL Databases gives examples of DELETE statements features