जवाबों:
उपयोग करें INSERT ... SELECT
:
insert into your_table (c1, c2, ...)
select c1, c2, ...
from your_table
where id = 1
जहां c1, c2, ...
को छोड़कर सभी स्तंभ हैं id
। यदि आप स्पष्ट रूप id
से 2 के साथ सम्मिलित करना चाहते हैं, तो उसे अपनी INSERT कॉलम सूची और अपने चयन में शामिल करें:
insert into your_table (id, c1, c2, ...)
select 2, c1, c2, ...
from your_table
where id = 1
आपको id
पाठ्यक्रम के दूसरे मामले में 2 के संभावित डुप्लिकेट का ध्यान रखना होगा ।
IMO, सबसे अच्छा लगता है कि sql स्टेटमेंट का उपयोग केवल उस पंक्ति को कॉपी करने के लिए किया जाता है, जबकि एक ही समय में केवल उन कॉलम को संदर्भित करना चाहिए जो आप बदलना चाहते हैं और बदलना चाहते हैं।
CREATE TEMPORARY TABLE temp_table ENGINE=MEMORY
SELECT * FROM your_table WHERE id=1;
UPDATE temp_table SET id=NULL; /* Update other values at will. */
INSERT INTO your_table SELECT * FROM temp_table;
DROP TABLE temp_table;
यह भी देखें av8n.com - कैसे एक एसक्यूएल रिकॉर्ड क्लोन करें
लाभ:
your_table
परमाणु ऑपरेशन में एक पूरी तरह से सही रिकॉर्ड डाला जाता है ।Error Code: 1113. A table must have at least 1 column
।
SET id=NULL
त्रुटि हो सकती है Column 'id' cannot be null
। द्वारा प्रतिस्थापित किया जाना चाहिएUPDATE temp_table SET id = (SELECT MAX(id) + 1 as id FROM your_table);
कहो मेज है user(id, user_name, user_email)
।
आप इस क्वेरी का उपयोग कर सकते हैं:
INSERT INTO user (SELECT NULL,user_name, user_email FROM user WHERE id = 1)
Result: near "SELECT": syntax error
इससे मदद मिली और यह एक BLOB / TEXT कॉलम का समर्थन करता है।
CREATE TEMPORARY TABLE temp_table
AS
SELECT * FROM source_table WHERE id=2;
UPDATE temp_table SET id=NULL WHERE id=2;
INSERT INTO source_table SELECT * FROM temp_table;
DROP TEMPORARY TABLE temp_table;
USE source_table;
एक त्वरित, स्वच्छ समाधान के लिए जिसे आपको कॉलम का नाम देने की आवश्यकता नहीं है, आप यहां बताए अनुसार तैयार किए गए विवरण का उपयोग कर सकते हैं: https://stackoverflow.com/a/23964285/292677
यदि आपको एक जटिल समाधान की आवश्यकता है तो आप अक्सर ऐसा कर सकते हैं, आप इस प्रक्रिया का उपयोग कर सकते हैं:
DELIMITER $$
CREATE PROCEDURE `duplicateRows`(_schemaName text, _tableName text, _whereClause text, _omitColumns text)
SQL SECURITY INVOKER
BEGIN
SELECT IF(TRIM(_omitColumns) <> '', CONCAT('id', ',', TRIM(_omitColumns)), 'id') INTO @omitColumns;
SELECT GROUP_CONCAT(COLUMN_NAME) FROM information_schema.columns
WHERE table_schema = _schemaName AND table_name = _tableName AND FIND_IN_SET(COLUMN_NAME,@omitColumns) = 0 ORDER BY ORDINAL_POSITION INTO @columns;
SET @sql = CONCAT('INSERT INTO ', _tableName, '(', @columns, ')',
'SELECT ', @columns,
' FROM ', _schemaName, '.', _tableName, ' ', _whereClause);
PREPARE stmt1 FROM @sql;
EXECUTE stmt1;
END
आप इसे चला सकते हैं:
CALL duplicateRows('database', 'table', 'WHERE condition = optional', 'omit_columns_optional');
उदाहरण
duplicateRows('acl', 'users', 'WHERE id = 200'); -- will duplicate the row for the user with id 200
duplicateRows('acl', 'users', 'WHERE id = 200', 'created_ts'); -- same as above but will not copy the created_ts column value
duplicateRows('acl', 'users', 'WHERE id = 200', 'created_ts,updated_ts'); -- same as above but also omits the updated_ts column
duplicateRows('acl', 'users'); -- will duplicate all records in the table
अस्वीकरण: यह समाधान केवल उन लोगों के लिए है जो अक्सर कई तालिकाओं में पंक्तियों को दोहरा रहे हैं, अक्सर। यह एक दुष्ट उपयोगकर्ता के हाथों में खतरनाक हो सकता है।
आप '0' में ऑटो-इंक्रीमेंट के लिए कॉलम के मान के रूप में भी पास कर सकते हैं, रिकॉर्ड बनाते समय सही मूल्य का उपयोग किया जाएगा। यह अस्थायी तालिकाओं की तुलना में बहुत आसान है।
स्रोत: MySQL में पंक्तियों की प्रतिलिपि बनाना (दूसरा कमेंट, TRiG द्वारा, पहले समाधान के लिए, विद्या द्वारा देखें)
यहाँ बहुत सारे शानदार उत्तर। नीचे संग्रहीत कार्यविधि का एक नमूना है जो मैंने वेब ऐप के लिए इस कार्य को पूरा करने के लिए लिखा था जिसे मैं विकसित कर रहा हूं:
-- SET NOCOUNT ON added to prevent extra result sets from
-- interfering with SELECT statements.
SET NOCOUNT ON
-- Create Temporary Table
SELECT * INTO #tempTable FROM <YourTable> WHERE Id = Id
--To trigger the auto increment
UPDATE #tempTable SET Id = NULL
--Update new data row in #tempTable here!
--Insert duplicate row with modified data back into your table
INSERT INTO <YourTable> SELECT * FROM #tempTable
-- Drop Temporary Table
DROP TABLE #tempTable
insert into MyTable(field1, field2, id_backup)
select field1, field2, uniqueId from MyTable where uniqueId = @Id;
यदि आप MySQL कार्यक्षेत्र का उपयोग करने में सक्षम हैं, तो आप पंक्ति को राइट-क्लिक करके और 'कॉपी पंक्ति' का चयन करके ऐसा कर सकते हैं, और फिर खाली पंक्ति पर राइट-क्लिक करके 'पेस्ट पंक्ति' का चयन कर सकते हैं, और फिर आईडी बदल सकते हैं, और फिर 'लागू करें' पर क्लिक करें।
पंक्ति की प्रतिलिपि बनाएँ:
प्रतिलिपि बनाई गई पंक्ति को रिक्त पंक्ति में चिपकाएँ:
आईडी बदलें:
लागू:
मैं उसी सुविधा की तलाश में था लेकिन मैं MySQL का उपयोग नहीं करता। मैं प्राथमिक कुंजी (आईडी) को छोड़कर सभी क्षेत्रों को कॉपी करना चाहता था। यह एक शॉट क्वेरी थी, जिसे किसी स्क्रिप्ट या कोड में उपयोग नहीं किया जाना था।
मुझे पीएल / एसक्यूएल के साथ अपना रास्ता मिल गया लेकिन मुझे यकीन है कि कोई अन्य एसक्यूएल आईडीई करेगा। मैंने एक बेसिक किया
SELECT *
FROM mytable
WHERE id=42;
फिर इसे एक SQL फ़ाइल में निर्यात करें जहाँ मुझे मिल सके
INSERT INTO table (col1, col2, col3, ... , col42)
VALUES (1, 2, 3, ..., 42);
मैंने अभी इसे संपादित किया और इसका उपयोग किया:
INSERT INTO table (col1, col2, col3, ... , col42)
VALUES (mysequence.nextval, 2, 3, ..., 42);
मैं इस बात की भिन्नता का उपयोग करता हूं कि बहुत कम पोस्ट किया गया है:
INSERT INTO something_log
SELECT NULL, s.*
FROM something AS s
WHERE s.id = 1;
जब तक तालिकाओं में समान फ़ील्ड होते हैं (लॉग टेबल पर ऑटो वेतन वृद्धि को छोड़कर), तब यह अच्छी तरह से काम करता है।
चूंकि मैं जब भी संभव हो संग्रहीत प्रक्रियाओं का उपयोग करता हूं (अन्य प्रोग्रामर जो डेटाबेस से बहुत परिचित नहीं हैं, पर जीवन को आसान बनाने के लिए), यह एक मेज पर एक नया क्षेत्र जोड़ने पर हर बार वापस जाने और प्रक्रियाओं को अपडेट करने की समस्या को हल करता है।
यह भी सुनिश्चित करता है कि यदि आप एक तालिका में नए फ़ील्ड जोड़ते हैं, तो वे आपके डेटाबेस के प्रश्नों को अपडेट किए बिना तुरंत लॉग टेबल में दिखाई देने लगेंगे (जब तक कि आपके पास कुछ ऐसा न हो जो स्पष्ट रूप से फ़ील्ड सेट करता है)
चेतावनी: आप एक ही समय में किसी भी नए फ़ील्ड को दोनों तालिकाओं में जोड़ना सुनिश्चित करेंगे ताकि फ़ील्ड ऑर्डर समान रहे ... अन्यथा आपको अजीब बग्स मिलने लगेंगे। यदि आप केवल एक है कि डेटाबेस इंटरफेस लिखता है और आप बहुत सावधान हैं तो यह अच्छी तरह से काम करता है। अन्यथा, अपने सभी क्षेत्रों के नामकरण से चिपके रहें।
नोट: दूसरे विचार पर, जब तक कि आप एक एकल परियोजना पर काम नहीं कर रहे हैं, तो आप सुनिश्चित हैं कि अन्य लोगों के पास इस पर काम करने के लिए सभी फ़ील्ड नामों को स्पष्ट रूप से सूचीबद्ध करने और अपने स्कीमा परिवर्तन के रूप में अपने लॉग स्टेटमेंट को अपडेट करने के लिए छड़ी नहीं होगी। यह शॉर्टकट संभवतः लंबे समय तक सिरदर्द के लायक नहीं है, जो इसका कारण हो सकता है ... विशेष रूप से उत्पादन प्रणाली पर।
INSERT INTO `dbMyDataBase`.`tblMyTable` ( `IdAutoincrement`, `Column2`, `Column3`, `Column4` ) चुनते हैं शून्य, `Column2`, `Column3`, 'CustomValue' AS Column4 `DbMyDataBase`.`tblMyTable` से जहां `tblMyTable`.`Cumn 2` = 'UniqueValueOfTheKey' ; / * mySQL 5.6 * /