답변:
사용 INSERT ... SELECT
:
insert into your_table (c1, c2, ...)
select c1, c2, ...
from your_table
where id = 1
를 c1, c2, ...
제외한 모든 열은 어디에 있습니까 id
? id
를 2 로 명시 적으로 삽입하려면 INSERT 열 목록과 SELECT에 포함하십시오.
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-SQL 레코드 복제 방법 도 참조하십시오.
혜택:
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의 첫 번째 솔루션에 대한 Lore의 두 번째 주석 참조)
여기에 많은 훌륭한 답변이 있습니다. 다음은 개발중인 웹 응용 프로그램에 대해이 작업을 수행하기 위해 작성한 저장 프로 시저 샘플입니다.
-- 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
나는 같은 기능을 찾고 있었지만 MySQL을 사용하지 않습니다. 물론 기본 키 (id)를 제외한 모든 필드를 복사하고 싶었습니다. 이것은 스크립트 나 코드에서 사용되지 않는 원샷 쿼리입니다.
PL / SQL과 관련된 길을 찾았지만 다른 SQL IDE가 할 것이라고 확신합니다. 나는 기본을했다
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);
mu가 너무 짧게 게시 된 변형을 사용하는 경향이 있습니다.
INSERT INTO something_log
SELECT NULL, s.*
FROM something AS s
WHERE s.id = 1;
테이블에 동일한 필드가있는 한 (로그 테이블의 자동 증분 제외), 잘 작동합니다.
가능하면 데이터베이스에 익숙하지 않은 다른 프로그래머가 쉽게 사용할 수 있도록 저장 프로 시저를 사용하므로 테이블에 새 필드를 추가 할 때마다 프로 시저로 돌아가서 업데이트해야하는 문제를 해결합니다.
또한 테이블에 새 필드를 추가하면 데이터베이스 쿼리를 업데이트하지 않고도 로그 테이블에 즉시 표시되기 시작합니다 (물론 필드를 명시 적으로 설정 한 경우가 아닌 한)
경고 : 필드 순서가 동일하게 유지되도록 두 테이블에 새 필드를 동시에 추가해야합니다. 그렇지 않으면 이상한 버그가 발생합니다. 데이터베이스 인터페이스를 작성하는 유일한 사람이고 매우 조심하면 잘 작동합니다. 그렇지 않으면 모든 필드의 이름을 지정하십시오.
참고 : 솔로 프로젝트에서 작업하지 않는 한 다른 프로젝트에서는 모든 필드 이름을 명시 적으로 나열하고 스키마가 변경되면 로그 문을 업데이트하는 것이 아닙니다. 이 지름길은 아마도 생산 시스템에서 발생할 수있는 장기 두통의 가치가 없을 것입니다.
`dbMyDataBase`에 삽입하십시오 .`tblMyTable` ( `자동 증가`, `열 2`, `열 3`, `열 4` ) 고르다 없는, `열 2`, `열 3`, 'CustomValue'AS Column4 `dbMyDataBase`.`tblMyTable`에서 `tblMyTable`.`Column2` = 'UniqueValueOfTheKey'위치 ; / * mySQL 5.6 * /