php – 在MySQL中复制一条记录

前端之家收集整理的这篇文章主要介绍了php – 在MySQL中复制一条记录前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我有一个表,我想复制表中的特定行.我知道这不是最好的做事方式,但我们正在寻找快速解决方案.

这里的内容比我最初的想法更难,我需要做的就是将整个记录复制到MySql自动增量表中的新记录,而无需指定每个字段.这是因为该表可能在将来发生变化,并可能会破坏重复.我将从PHP复制MysqL记录.

这是一个问题,因为在’SELECT *’查询中,MysqL将尝试复制正在复制的记录的ID,这会产生重复的ID错误.

这封锁了:
 INSERT INTO客户SELECT * FROM customer WHERE customerid = 9181.它还阻止了INSERT INTO客户(Field1,Field2,…)SELECT Field1,….. FROM customer WHERE customerid = 9181.

有没有办法从PHPMysqL做到这一点?

最佳答案
我终于找到了这段代码.我相信它将来会帮助别人.所以这就是.

  1. function DuplicateMysqLRecord ($table,$id_field,$id) {
  2. // load the original record into an array
  3. $result = MysqL_query("SELECT * FROM {$table} WHERE {$id_field}={$id}");
  4. $original_record = MysqL_fetch_assoc($result);
  5. // insert the new record and get the new auto_increment id
  6. MysqL_query("INSERT INTO {$table} (`{$id_field}`) VALUES (NULL)");
  7. $newid = MysqL_insert_id();
  8. // generate the query to update the new record with the prevIoUs values
  9. $query = "UPDATE {$table} SET ";
  10. foreach ($original_record as $key => $value) {
  11. if ($key != $id_field) {
  12. $query .= '`'.$key.'` = "'.str_replace('"','\"',$value).'",';
  13. }
  14. }
  15. $query = substr($query,strlen($query)-2); # lop off the extra trailing comma
  16. $query .= " WHERE {$id_field}={$newid}";
  17. MysqL_query($query);
  18. // return the new id
  19. return $newid;
  20. }

这是文章http://www.epigroove.com/posts/79/how_to_duplicate_a_record_in_mysql_using_php链接

猜你在找的MySQL相关文章