在MySQL中复制记录

Pas*_*sta 5 php mysql sql

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

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

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

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

有没有办法从PHP或MySQL做到这一点?

Pas*_*sta 12

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

function DuplicateMySQLRecord ($table, $id_field, $id) {
  // load the original record into an array
  $result = mysql_query("SELECT * FROM {$table} WHERE {$id_field}={$id}");
  $original_record = mysql_fetch_assoc($result);

  // insert the new record and get the new auto_increment id
  mysql_query("INSERT INTO {$table} (`{$id_field}`) VALUES (NULL)");
  $newid = mysql_insert_id();

  // generate the query to update the new record with the previous values
  $query = "UPDATE {$table} SET ";
  foreach ($original_record as $key => $value) {
    if ($key != $id_field) {
        $query .= '`'.$key.'` = "'.str_replace('"','\"',$value).'", ';
    }
  }
  $query = substr($query,0,strlen($query)-2); # lop off the extra trailing comma
  $query .= " WHERE {$id_field}={$newid}";
  mysql_query($query);

  // return the new id
  return $newid;
}
Run Code Online (Sandbox Code Playgroud)

以下是http://www.epigroove.com/posts/79/how_to_duplicate_a_record_in_mysql_using_php文章的链接