在MySQL中,我试图复制一行自增量列ID=1,并将数据插入到相同的表中,作为列ID=2的新行。
如何在单个查询中做到这一点?
在MySQL中,我试图复制一行自增量列ID=1,并将数据插入到相同的表中,作为列ID=2的新行。
如何在单个查询中做到这一点?
当前回答
假设表是user(id, user_name, user_email)。
你可以使用这个查询:
INSERT INTO user (SELECT NULL,user_name, user_email FROM user WHERE id = 1)
其他回答
Insert into your table(col1,col2,col3) select col1+1,col2,col3 from your_table where col1=1;
注意:如果col1是主键,请确保自增后col1的新值不是重复项。
INSERT INTO `dbMyDataBase`.`tblMyTable` ( `IdAutoincrement`, `Column2`, `Column3`, `Column4` ) SELECT NULL, `Column2`, `Column3`, 'CustomValue' AS Column4 FROM `dbMyDataBase`.`tblMyTable` WHERE `tblMyTable`.`Column2` = 'UniqueValueOfTheKey' ; /* mySQL 5.6 */
转储您想要sql的行,然后使用生成的sql,减去ID列,将其导入。
insert into MyTable(field1, field2, id_backup)
select field1, field2, uniqueId from MyTable where uniqueId = @Id;
试试这个:
INSERT INTO test_table (SELECT null,txt FROM test_table)
每次运行此查询时,这将再次插入所有具有新id的行。值将呈指数增长。
我使用了一个有两列的表,即id和txt, id是自动递增的。