हटाएं (एसक्यूएल): Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|SQL database query language statement}} {{redirect|DELETE|other uses|Delete (disambiguation){{!}}Delete}} {{one source|date=September 2019}} डेटा...")
 
No edit summary
Line 1: Line 1:
{{Short description|SQL database query language statement}}
{{Short description|SQL database query language statement}}
{{redirect|DELETE|other uses|Delete (disambiguation){{!}}Delete}}
{{redirect|DELETE|other uses|Delete (disambiguation){{!}}Delete}}
{{one source|date=September 2019}}
डेटाबेस स्ट्रक्चर्ड क्वेरी लैंग्वेज ([[एसक्यूएल]]) में, DELETE स्टेटमेंट [[तालिका (डेटाबेस)]] से एक या एक से अधिक रिकॉर्ड्स को हटा देता है। समुच्चय उपसमुच्चय को एक शर्त का उपयोग करके विलोपन के लिए परिभाषित किया जा सकता है, अन्यथा सभी रिकॉर्ड हटा दिए जाते हैं।<ref>{{cite web|url=https://www.w3schools.com/Sql/sql_delete.asp|title=SQL Delete Statement|publisher=w3schools.com}}</ref> कुछ डेटाबेस#डेटाबेस प्रबंधन प्रणाली (डीबीएमएस), जैसे [[MySQL]], समुच्चयDELETE कथन के साथ कई तालिकाओं से पंक्तियों को हटाने की अनुमति देता है (इसे कभी-कभी मल्टी-टेबल DELETE कहा जाता है)।
डेटाबेस स्ट्रक्चर्ड क्वेरी लैंग्वेज ([[एसक्यूएल]]) में, DELETE स्टेटमेंट [[तालिका (डेटाबेस)]] से एक या एक से अधिक रिकॉर्ड्स को हटा देता है। एक उपसमुच्चय को एक शर्त का उपयोग करके विलोपन के लिए परिभाषित किया जा सकता है, अन्यथा सभी रिकॉर्ड हटा दिए जाते हैं।<ref>{{cite web|url=https://www.w3schools.com/Sql/sql_delete.asp|title=SQL Delete Statement|publisher=w3schools.com}}</ref> कुछ डेटाबेस#डेटाबेस प्रबंधन प्रणाली (डीबीएमएस), जैसे [[MySQL]], एक DELETE कथन के साथ कई तालिकाओं से पंक्तियों को हटाने की अनुमति देता है (इसे कभी-कभी मल्टी-टेबल DELETE कहा जाता है)।


== उदाहरण ==
== उदाहरण ==
Line 46: Line 45:
== संबंधित तालिकाओं के साथ उदाहरण ==
== संबंधित तालिकाओं के साथ उदाहरण ==


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


{|
{|
Line 94: Line 93:
  पा से हटाएं जहां पिड = 1;
  पा से हटाएं जहां पिड = 1;
</वाक्यविन्यास हाइलाइट>
</वाक्यविन्यास हाइलाइट>
संदर्भित सत्यनिष्ठा बनाए रखने के लिए, जो के रिकॉर्ड को व्यक्ति और पिता दोनों से हटा दिया जाना चाहिए। अलग-अलग संबंधपरक डेटाबेस प्रबंधन प्रणालियों में अखंडता को बनाए रखने के तरीके अलग-अलग हो सकते हैं।{{Citation needed|date=February 2007}} यह हो सकता है कि केवल तीन तालिकाओं से परे, डेटाबेस को एक ट्रिगर के साथ भी स्थापित किया गया हो ताकि जब भी किसी व्यक्ति से कोई पंक्ति हटाई जाए तो किसी भी लिंक की गई पंक्तियों को पा से हटा दिया जाएगा। फिर पहला कथन:
संदर्भित सत्यनिष्ठा बनाए रखने के लिए, जो के रिकॉर्ड को व्यक्ति और पिता दोनों से हटा दिया जाना चाहिए। अलग-अलग संबंधपरक डेटाबेस प्रबंधन प्रणालियों में अखंडता को बनाए रखने के तरीके अलग-अलग हो सकते हैं।{{Citation needed|date=February 2007}} यह हो सकता है कि केवल तीन तालिकाओं से परे, डेटाबेस को समुच्चयट्रिगर के साथ भी स्थापित किया गया हो ताकि जब भी किसी व्यक्ति से कोई पंक्ति हटाई जाए तो किसी भी लिंक की गई पंक्तियों को पा से हटा दिया जाएगा। फिर पहला कथन:
<वाक्यविन्यास लैंग = एसक्यूएल>
<वाक्यविन्यास लैंग = एसक्यूएल>
  व्यक्ति से हटाएं जहां पीआईडी=1;
  व्यक्ति से हटाएं जहां पीआईडी=1;
Line 104: Line 103:


== विशेषताएं ==
== विशेषताएं ==
* यह एक डीएमएल (डेटा मैनीपुलेशन लैंग्वेज) कमांड है, इसलिए इस कमांड के लिए निम्नलिखित कमांड का उपयोग किया जाता है: COMMIT और ROLLBACK
* यह समुच्चयडीएमएल (डेटा मैनीपुलेशन लैंग्वेज) कमांड है, इसलिए इस कमांड के लिए निम्नलिखित कमांड का उपयोग किया जाता है: COMMIT और ROLLBACK
* तालिका से सभी या कुछ रिकॉर्ड हटा देता है, आप WHERE क्लॉज का उपयोग करके हटाए जाने वाले रिकॉर्ड को सीमित कर सकते हैं
* तालिका से सभी या कुछ रिकॉर्ड हटा देता है, आप WHERE क्लॉज का उपयोग करके हटाए जाने वाले रिकॉर्ड को सीमित कर सकते हैं
* तालिका में (टेबलस्पेस में) डेटा द्वारा कब्जा कर लिया गया स्थान खाली नहीं करता है
* तालिका में (टेबलस्पेस में) डेटा द्वारा कब्जा कर लिया गया स्थान खाली नहीं करता है
Line 110: Line 109:
* DELETE, TRUNCATE की तुलना में बहुत धीमी गति से काम करता है
* DELETE, TRUNCATE की तुलना में बहुत धीमी गति से काम करता है
* आप ROLLBACK कमांड का उपयोग करके रिकॉर्ड हटाने की कार्रवाई को पूर्ववत कर सकते हैं
* आप ROLLBACK कमांड का उपयोग करके रिकॉर्ड हटाने की कार्रवाई को पूर्ववत कर सकते हैं
* DELETE के लिए एक साझा टेबल लॉक की आवश्यकता होती है
* DELETE के लिए समुच्चयसाझा टेबल लॉक की आवश्यकता होती है
* आग लगा देता है
* आग लगा देता है
* DELETE का उपयोग डेटाबेस लिंक के मामले में किया जा सकता है
* DELETE का उपयोग डेटाबेस लिंक के मामले में किया जा सकता है
Line 122: Line 121:


== संबंधित आदेश ==
== संबंधित आदेश ==
तालिका से सभी पंक्तियों को हटाने में बहुत समय लग सकता है। कुछ [[डीबीएमएस]]{{Clarify|date=September 2009}} एक [[ट्रंकेट (एसक्यूएल)]] कमांड की पेशकश करें जो बहुत तेजी से काम करता है, क्योंकि यह केवल मेटाडेटा को बदलता है और आमतौर पर बाधाओं को लागू करने या ट्रिगर्स को सक्रिय करने में समय व्यतीत नहीं करता है।
तालिका से सभी पंक्तियों को हटाने में बहुत समय लग सकता है। कुछ [[डीबीएमएस]]{{Clarify|date=September 2009}} समुच्चय[[ट्रंकेट (एसक्यूएल)]] कमांड की पेशकश करें जो बहुत तेजी से काम करता है, क्योंकि यह केवल मेटाडेटा को बदलता है और आमतौर पर बाधाओं को लागू करने या ट्रिगर्स को सक्रिय करने में समय व्यतीत नहीं करता है।


DELETE केवल पंक्तियों को हटाता है। किसी तालिका को पूरी तरह से हटाने के लिए [[ड्रॉप (एसक्यूएल)]] कमांड का उपयोग किया जा सकता है।
DELETE केवल पंक्तियों को हटाता है। किसी तालिका को पूरी तरह से हटाने के लिए [[ड्रॉप (एसक्यूएल)]] कमांड का उपयोग किया जा सकता है।

Revision as of 11:09, 22 February 2023

डेटाबेस स्ट्रक्चर्ड क्वेरी लैंग्वेज (एसक्यूएल) में, DELETE स्टेटमेंट तालिका (डेटाबेस) से एक या एक से अधिक रिकॉर्ड्स को हटा देता है। समुच्चय उपसमुच्चय को एक शर्त का उपयोग करके विलोपन के लिए परिभाषित किया जा सकता है, अन्यथा सभी रिकॉर्ड हटा दिए जाते हैं।[1] कुछ डेटाबेस#डेटाबेस प्रबंधन प्रणाली (डीबीएमएस), जैसे MySQL, समुच्चयDELETE कथन के साथ कई तालिकाओं से पंक्तियों को हटाने की अनुमति देता है (इसे कभी-कभी मल्टी-टेबल DELETE कहा जाता है)।

उदाहरण

तालिका पाई से पंक्ति (डेटाबेस) हटाएं जहां कॉलम (डेटाबेस) स्वाद लेमन मेरिंग्यू के बराबर है: <वाक्यविन्यास लैंग = एसक्यूएल> पाई से हटाएं

जहां स्वाद = 'नींबू मेरिंग्यू';

</वाक्यविन्यास हाइलाइट>

यदि ऊँचाई का मान 80 से कम है, तो पेड़ों में पंक्तियों को हटा दें। <वाक्यविन्यास लैंग = एसक्यूएल> पेड़ों से हटाएं

जहां ऊंचाई <80;

</वाक्यविन्यास हाइलाइट>

mytable से सभी पंक्तियां हटाएं: <वाक्यविन्यास लैंग = एसक्यूएल> मायटेबल से हटाएं; </वाक्यविन्यास हाइलाइट>

mytable से पंक्तियाँ जहाँ स्थिति में सबक्वेरी का उपयोग करके हटाएं: <वाक्यविन्यास लैंग = एसक्यूएल> मायटेबल से हटाएं

जहां आईडी में (
      आईडी चुनें
        mytable2 से
     );

</वाक्यविन्यास हाइलाइट>

मानों की सूची का उपयोग करके mytable से पंक्तियां हटाएं: <वाक्यविन्यास लैंग = एसक्यूएल> मायटेबल से हटाएं

जहां आईडी में (
      मान1,
      मान2,
      मान3,
      मान4,
      value5
     );

</वाक्यविन्यास हाइलाइट>

संबंधित तालिकाओं के साथ उदाहरण

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

person
pid name
1 Joe
2 Bob
3 Ann
address
aid description
100 2001 Main St.
200 35 Pico Blvd.
pa
pid aid
1 100
2 100
3 100
1 200

पीए टेबल व्यक्ति और एड्रेस टेबल से संबंधित है, यह दर्शाता है कि जो, बॉब और ऐन सभी 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 केवल पंक्तियों को हटाता है। किसी तालिका को पूरी तरह से हटाने के लिए ड्रॉप (एसक्यूएल) कमांड का उपयोग किया जा सकता है।

संदर्भ

  1. "SQL Delete Statement". w3schools.com.


बाहरी संबंध