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

डुप्लिकेट कुंजी अद्यतन पर SQL अद्यतन

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

यदि आप ऐसा करते हैं, तो आपका "वन-टाइम अपडेट" अब सुरक्षित रूप से किया जा सकता है, जब तक कि आपको काम करने के लिए कुछ अस्थायी टेबल बनाने में कोई आपत्ति नहीं है। कुछ इस तरह:

समान स्कीमा के साथ कुछ अस्थायी तालिकाएँ बनाएँ, लेकिन अद्वितीय . के बिना तीन-स्तंभ अनुक्रमणिका - आपके पास एक गैर-अद्वितीय अनुक्रमणिका हो सकती है, क्योंकि यह आपके द्वारा निष्पादित की जाने वाली क्वेरी में सहायता करेगी;

उन रिकॉर्ड्स की प्रतिलिपि बनाएँ जिन्हें आपको पहली तालिका में संसाधित करने की आवश्यकता है (अद्वितीय पूर्णांक प्राथमिक कुंजी सहित);

सभी detail अपडेट करें अस्थायी तालिका में आपको जिन स्तंभों को अद्यतन करने की आवश्यकता है;

INSERT ... SELECT SUM . के साथ और GROUP BY उन अभिलेखों को दूसरी तालिका में मर्ज करने के लिए;

INSERT INTO temp2 (...whatever...) SELECT ...whatever..., SUM(no) FROM temp1 GROUP BY ...whatever...

अंत में, मूल तालिका से temp1 तालिका में सभी रिकॉर्ड हटाएं (पूर्णांक प्राथमिक कुंजी का उपयोग करके), और temp2 तालिका में रिकॉर्ड्स को मूल तालिका में डालें।



  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. MySQL में varbinary कैसे स्टोर करें?

  2. मैक पर लैरवेल की स्थापना php कारीगर माइग्रेट त्रुटि:ऐसी कोई फ़ाइल या निर्देशिका नहीं

  3. ध्यान में न आया अपवाद 'PDOException' संदेश के साथ 'SQLSTATE [HY093]:अमान्य पैरामीटर संख्या'

  4. Google मानचित्र, PHP और MySQL पर स्थान खोज के पास

  5. पहले-पहले, पहले-बाहर मूल्य निर्धारण के आधार पर लाभ की गणना करें