-3

我正在用准备好的语句在 php 中做一些工作。我的任务是首先从一个表中选择一些数据,然后将数据插入到另一个表中。如何在准备好的语句中使用 while 循环来插入记录?

这是代码:

stmt=$db->prepare("SELECT userid, order_number, balance from plus_wallet  limit 0,3");
$stmt->execute();
$stmt->bind_result($userid, $orderid, $balance);
while($stmt->fetch()) {
    $stmt1=$db->prepare("INSERT INTO `plus_user_wallet`(`userid`, `balance`, `update_time`) VALUES (?,?, NOW() + INTERVAL 45000 second)");
    $stmt1->bind_param('ss' , $userid, $balance);
    $stmt1->execute();
    $stmt1->close();
    $stmt->close();
}
4

1 回答 1

1

如果该order_number字段在其他任何地方都不需要并且您选择它是因为它在表格中,您可以使用:

insert into
plus_user_wallet
    (userid,balance,update_time) 
select 
    userid,balance,now()+interval 45000 second
from
    plus_wallet
limit
    0,3;

如果您需要单个userid值,则可以通过添加where userid=?到 select 语句之后将其变为准备好的语句from plus_wallet

显然,如果您确实需要其他地方的 order_number,那么您将需要一个循环系统。

关于您的代码的一些注意事项:

  • 在 while 循环之外准备$stmt1- 这就是准备好的语句的重点
  • 在 while 循环完成后关闭所有准备好的语句
于 2013-09-23T12:59:54.097 回答