Database
 sql >> डेटाबेस >  >> RDS >> Database

शुरुआती के लिए SQL DELETE

इस लेख में मूल SQL DELETE शामिल है बयान जो शुरुआती अपने डेटाबेस टेबल से डेटा को हटाने के लिए उपयोग कर सकते हैं।

एकल पंक्ति हटाएं

यहां SQL का मूल उदाहरण दिया गया है DELETE बयान।

DELETE FROM Owners
WHERE OwnerId = 5;

इस मामले में हम उस पंक्ति को हटा देते हैं जहां OwnerId कॉलम का मान 4 . है ।

DELETE स्टेटमेंट DELETE FROM से शुरू होता है , उसके बाद तालिका का नाम (यानी वह तालिका जिसमें वह डेटा है जिसे आप हटाना चाहते हैं)।

कुछ डेटाबेस मैनेजमेंट सिस्टम (DBMS) में, FROM कीवर्ड वैकल्पिक है, लेकिन बेहतर पोर्टेबिलिटी के लिए इसे शामिल करना एक अच्छा विचार है (यदि आपको एक ही कोड को एक अलग DBMS पर चलाने की आवश्यकता है)।

आपको हमेशा एक WHERE . शामिल करना चाहिए खंड, जब तक कि आप तालिका से सभी पंक्तियों को हटाना नहीं चाहते।

हां, आपने उसे सही पढ़ा है। WHERE . को छोड़ना क्लॉज तालिका की सभी पंक्तियों को हटा देगा।

अधिकांश DBMS में कई अन्य विकल्प होते हैं जिनका उपयोग आप DELETE . के साथ कर सकते हैं कथन, लेकिन यहां सूचीबद्ध सबसे अधिक उपयोग किए जाने वाले हैं।

ध्यान दें कि DELETE कथन पूरी पंक्ति को हटा देता है। आप एक पंक्ति में किसी एक कॉलम का मान नहीं हटा सकते। ऐसा करने के लिए, SQL UPDATE का उपयोग करें बयान।

उदाहरण

इस उदाहरण में, हम तालिका से डेटा हटाते हैं।

सबसे पहले, आइए देखें कि तालिका में क्या है।

SELECT * FROM Owners;

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 1         | Homer       | Connery    | (308) 555-0100 | [email protected] |
| 2         | Bart        | Pitt       | (231) 465-3497 | [email protected]  |
| 3         | Nancy       | Stallone   | (489) 591-0408 | NULL              |
| 4         | Boris       | Biden      | (349) 611-8908 | [email protected] |
| 5         | Woody       | Eastwood   | (308) 555-0112 | [email protected] |
+-----------+-------------+------------+----------------+-------------------+

ठीक है, मालिक संख्या 5 को हटा दें, फिर तालिका का चयन करें।

DELETE FROM Owners
WHERE OwnerId = 5;

SELECT * FROM Owners;

परिणाम:

+-----------+-------------+------------+----------------+-------------------+
| OwnerId   | FirstName   | LastName   | Phone          | Email             |
|-----------+-------------+------------+----------------+-------------------|
| 1         | Homer       | Connery    | (308) 555-0100 | [email protected] |
| 2         | Bart        | Pitt       | (231) 465-3497 | [email protected]  |
| 3         | Nancy       | Stallone   | (489) 591-0408 | NULL              |
| 4         | Boris       | Biden      | (349) 611-8908 | [email protected] |
+-----------+-------------+------------+----------------+-------------------+

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

विदेशी कुंजी

यदि आप किसी अन्य तालिका में किसी विदेशी कुंजी द्वारा संदर्भित डेटा को हटाने का प्रयास करते हैं तो आपको एक त्रुटि मिल सकती है। ऐसा इसलिए है क्योंकि आप जिस तालिका से डेटा हटाने का प्रयास कर रहे हैं, वह संबंध में मूल तालिका है। विदेशी कुंजी वाली तालिका (चाइल्ड टेबल) पैरेंट टेबल के डेटा पर निर्भर करती है (यानी वह डेटा जिसे आप हटाने की कोशिश कर रहे हैं)।

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

एक विदेशी कुंजी द्वारा संदर्भित पंक्ति को हटाने का प्रयास करने का एक उदाहरण यहां दिया गया है।

DELETE FROM Owners
WHERE OwnerId = 3;

परिणाम:

Msg 547, Level 16, State 0, Line 1
The DELETE statement conflicted with the REFERENCE constraint "FK_Pets_Owners". The conflict occurred in database "PetHotel", table "dbo.Pets", column 'OwnerId'.

The statement has been terminated.

इस मामले में, एक त्रुटि उठाई गई थी, और पंक्ति को हटाया नहीं गया था।

इस उदाहरण में, Owners.OwnerId कॉलम इस तालिका की प्राथमिक कुंजी है। Pets called नामक एक अन्य तालिका एक OwnerId है कॉलम जो इस प्राथमिक कुंजी कॉलम को संदर्भित करता है, और इस मामले में, कम से कम एक पंक्ति है जो स्वामी संख्या 3 को संदर्भित कर रही है।

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

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

सावधानी! WHERE को भूल रहे हैं खंड

DELETE बयान बहुत खतरनाक बयान हो सकता है। अगर आप WHERE . को छोड़ देते हैं खंड, आप सभी को हटा देंगे तालिका में पंक्तियाँ।

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

लेकिन क्या होगा अगर ऐसा नहीं है। क्या होगा यदि आपके डिलीट स्टेटमेंट से कोई त्रुटि नहीं होती है?

चलो पता करते हैं!

चलिए एक और DELETE चलाते हैं कथन, लेकिन इस बार हम WHERE . शामिल करना भूल जाएंगे खंड। साथ ही, इस बार हम इसे उस तालिका के विरुद्ध चलाएंगे जो किसी रिश्ते में माता-पिता नहीं है।

सबसे पहले, आइए देखें कि तालिका में क्या है।

SELECT * FROM Pets;

परिणाम:

+---------+-------------+-----------+-----------+------------+
| PetId   | PetTypeId   | OwnerId   | PetName   | DOB        |
|---------+-------------+-----------+-----------+------------|
| 1       | 2           | 3         | Fluffy    | 2020-11-20 |
| 2       | 3           | 3         | Fetch     | 2019-08-16 |
| 3       | 2           | 2         | Scratch   | 2018-10-01 |
| 4       | 3           | 3         | Wag       | 2020-03-15 |
| 5       | 1           | 1         | Tweet     | 2020-11-28 |
| 6       | 3           | 4         | Fluffy    | 2020-09-17 |
| 7       | 3           | 2         | Bark      | NULL       |
| 8       | 2           | 4         | Meow      | NULL       |
+---------+-------------+-----------+-----------+------------+

ठीक है, तो हमारे पास आठ पालतू जानवर हैं। हम वास्तव में देख सकते हैं कि तीन पालतू जानवर मालिक संख्या 3 के स्वामित्व में हैं - मालिक जिसे हमने पिछले उदाहरण में हटाने का प्रयास किया था। यही कारण है कि हमें त्रुटि मिली।

फिर भी, चलिए आगे बढ़ते हैं और अपना DELETE चलाते हैं WHERE . के बिना स्टेटमेंट खंड, फिर तालिका को फिर से जांचें

DELETE FROM Pets;

SELECT * FROM Pets;

परिणाम:

(8 rows affected)
(0 rows affected)

(8 rows affected) भाग का अर्थ है कि आठ पंक्तियों को हटा दिया गया था।

(0 rows affected) भाग का अर्थ है कि कोई पंक्तियाँ नहीं चुनी गईं (क्योंकि तालिका में कोई पंक्तियाँ नहीं हैं।

ओह!

कई बार ऐसा भी हो सकता है कि आपको वास्तव में तालिका की सभी पंक्तियों को हटाना पड़े। तालिका के आकार के आधार पर, यह कथन आपके लिए आवश्यक होगा।

यदि आपको एक बड़ी तालिका को हटाना है, तो TRUNCATE TABLE . भी है , जो किसी तालिका या तालिका के निर्दिष्ट विभाजन से सभी पंक्तियों को हटा देता है, व्यक्तिगत पंक्ति विलोपन को लॉग किए बिना (DELETE स्टेटमेंट इन विलोपन को लॉग करता है)।

इसलिए, TRUNCATE TABLE तेज़ है और कम सिस्टम और लेन-देन लॉग संसाधनों का उपयोग करता है।

TRUNCATE TABLE . का उपयोग करने का उदाहरण :

TRUNCATE TABLE Owners;

ध्यान दें कि यदि तालिका को किसी विदेशी कुंजी बाधा द्वारा संदर्भित किया जा रहा है, तो यह काम नहीं कर सकता है, भले ही कोई चाइल्ड रो न हो। ऐसे मामलों में, DELETE इसके बजाय काम कर सकता है।


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. COUNT व्यंजक पर विधेय के लिए कार्डिनैलिटी अनुमान

  2. एसक्यूएल टेबल

  3. एसक्यूएल का उपयोग करके अपवादों के साथ क्लॉज द्वारा ऑर्डर कैसे लिखें

  4. PHP का उपयोग करके डेटाबेस से कनेक्ट करना

  5. SQL विदेशी कुंजी बाधा:Newbies के लिए अंतिम, आसान मार्गदर्शिका