INSERT ... ON DUPLICATE KEY UPDATE इस तरह से काम करता है कि यदि उसे एक डुप्लिकेट अद्वितीय या प्राथमिक कुंजी मिलती है, तो वह एक UPDATE निष्पादित करेगी। अद्यतन केवल तभी किया जाता है जब डुप्लिकेट मान होते हैं।
आइए पहले एक टेबल बनाएं -
mysql> create table DemoTable733 ( StudentId int NOT NULL AUTO_INCREMENT PRIMARY KEY, StudentName varchar(100), StudentMarks int, UNIQUE KEY Un_Name (StudentName) ); Query OK, 0 rows affected (0.60 sec)
इंसर्ट कमांड का उपयोग करके टेबल में कुछ रिकॉर्ड डालें -
mysql> insert into DemoTable733(StudentName,StudentMarks) values('John',45) ON DUPLICATE KEY UPDATE StudentMarks=86; Query OK, 1 row affected (0.19 sec) mysql> insert into DemoTable733(StudentName,StudentMarks) values('Adam',65) ON DUPLICATE KEY UPDATE StudentMarks=86; Query OK, 1 row affected (0.15 sec) mysql> insert into DemoTable733(StudentName,StudentMarks) values('Carol',75) ON DUPLICATE KEY UPDATE StudentMarks=86; Query OK, 1 row affected (0.08 sec) mysql> insert into DemoTable733(StudentName,StudentMarks) values('John',45) ON DUPLICATE KEY UPDATE StudentMarks=86; Query OK, 2 rows affected (0.12 sec)
चयन कथन का उपयोग करके तालिका से सभी रिकॉर्ड प्रदर्शित करें -
mysql> select *from DemoTable733;
यह निम्नलिखित आउटपुट देगा -
+-----------+-------------+--------------+ | StudentId | StudentName | StudentMarks | +-----------+-------------+--------------+ | 1 | John | 86 | | 2 | Adam | 65 | | 3 | Carol | 75 | +-----------+-------------+--------------+ 3 rows in set (0.00 sec)