MariaDB - डुप्लिकेट का प्रबंधन
मारियाडीबी, जैसा कि पहले के पाठों में चर्चा की गई है, कुछ स्थितियों में डुप्लिकेट रिकॉर्ड और तालिकाओं की अनुमति देता है। इनमें से कुछ डुप्लिकेट वास्तव में अलग-अलग डेटा या ऑब्जेक्ट प्रकारों के कारण, या ऑपरेशन ऑब्जेक्ट के अनूठे जीवन काल या भंडारण के परिणामस्वरूप डुप्लिकेट नहीं हैं। ये डुप्लिकेट भी आम तौर पर कोई समस्या नहीं है।
कुछ स्थितियों में, डुप्लिकेट समस्याएं पैदा करते हैं, और वे अक्सर निहित कार्यों या मारियाबीडी कमांड की उदार नीति के कारण दिखाई देते हैं। इस मुद्दे को नियंत्रित करने, डुप्लिकेट खोजने, डुप्लिकेट को हटाने और डुप्लिकेट निर्माण को रोकने के तरीके हैं।
रणनीतियाँ और उपकरण
डुप्लिकेट को प्रबंधित करने के चार प्रमुख तरीके हैं -
जोइन के साथ उनके लिए मछली, और उन्हें एक अस्थायी तालिका के साथ हटा दें।
डुप्लिकेट कुंजी पर डुप्लिकेट की खोज पर अद्यतन करने के लिए INSERT ... का उपयोग करें।
चयन कथन के परिणामों को कम करने और डुप्लिकेट को निकालने के लिए DISTINCT का उपयोग करें।
डुप्लिकेट के सम्मिलन को रोकने के लिए INSERT IGNORE का उपयोग करें।
अस्थायी तालिका के साथ जुड़ें का उपयोग करना
बस एक आंतरिक जुड़ाव की तरह अर्ध-सम्मिलित करें, और फिर एक अस्थायी तालिका के साथ पाए गए डुप्लिकेट को हटा दें।
INSERT का उपयोग करना
जब INSERT ... ON DUPLICATE KEY UPDATE को डुप्लीकेट यूनीक या प्राइमरी की की जानकारी मिलती है, तो यह एक अपडेट करता है। कई विशिष्ट कुंजियों की खोज करने पर, यह केवल पहले अपडेट करता है। इसलिए, कई अद्वितीय सूचकांकों के साथ तालिकाओं पर इसका उपयोग न करें।
निम्नलिखित उदाहरण की समीक्षा करें, जो यह बताता है कि एक आबादी वाले क्षेत्र में प्रविष्टि पर अनुक्रमित मूल्यों वाले तालिका में क्या होता है -
INSERT INTO add_dupl VALUES (1,'Apple');
ERROR 1062 (23000): Duplicate entry '1' for key 'PRIMARY'
Note - यदि यह कोई कुंजी नहीं पाता है, तो INSERT ... DUPLICATE KEY पर अद्यतन सामान्य कथन की तरह निष्पादित होता है।
DISTINCT का उपयोग करना
परिणाम से डुप्लिकेट क्लॉज डुप्लिकेट को हटा देते हैं। DISTINCT क्लॉज के लिए सामान्य सिंटैक्स निम्नानुसार है -
SELECT DISTINCT fields
FROM table
[WHERE conditions];
Note - एक DISTINCT क्लॉज वाले बयान के परिणाम -
एक अभिव्यक्ति का उपयोग करते समय, यह इसके लिए अद्वितीय मान लौटाता है।
कई अभिव्यक्तियों का उपयोग करते समय, यह अद्वितीय संयोजन देता है।
यह NULL मूल्यों की उपेक्षा नहीं करता है; इस प्रकार, परिणामों में अद्वितीय मान के रूप में NULL भी होते हैं।
एकल अभिव्यक्ति के लिए DISTINCT क्लॉज का उपयोग करके निम्नलिखित कथन की समीक्षा करें -
SELECT DISTINCT product_id
FROM products
WHERE product_name = 'DustBlaster 5000';
कई उदाहरणों का उपयोग करके निम्नलिखित उदाहरण की समीक्षा करें -
SELECT DISTINCT product_name, product_id
FROM products
WHERE product_id < 30
INSERT IGNORE का उपयोग करना
एक INSERT IGNORE स्टेटमेंट ने डुप्लिकेट रिकॉर्ड की खोज पर मारबिडी को प्रविष्टि रद्द करने का निर्देश दिया। नीचे दिए गए इसके उपयोग के एक उदाहरण की समीक्षा करें -
mysql> INSERT IGNORE INTO customer_tbl (LN, FN)
VALUES( 'Lex', 'Luther');
इसके अलावा, डुप्लिकेट के पीछे के तर्क पर ध्यान दें। कुछ तालिकाओं को उस तालिका डेटा की प्रकृति के आधार पर डुप्लिकेट की आवश्यकता होती है। डुप्लिकेट रिकॉर्ड को प्रबंधित करने के लिए आपकी रणनीति में जो जरूरत है उसे रोकें।