2017-04-27 33 views
0

執行多個查詢在第一選擇查詢,如果id存在只是更新量在我的情況下,否則執行insert(id, quantity)查詢 剛剛更新查詢執行PHP PDO環路

$fodid = $data->orfid; 
$quantity = $data->orqnt; 

include('db.php');  

try{        
    $sqlchk="SELECT `orfoodid` AS FROM `orders` where `orfoodid`=':chkfoodid';"; 
    $sqlupdate="UPDATE `resturant`.`orders` SET `orfoodqnt` = ':chcount' WHERE `orders`.`orfoodid` = ':chfodid';"; 
    $sql="INSERT INTO `resturant`.`orders` (`orfoodid`, `orfoodqnt`) VALUES (:foodid,:count);"; 

    for($i=0;$i<sizeof($fodid);$i++){ 

     $rs = $conn->prepare($sqlchk); 
     $rs->execute(array(':chkfoodid'=>$fodid[$i]));  
     $result=$rs->fetch(PDO::FETCH_ASSOC);  

     if(!$result) 
     { 
      $rs = $conn->prepare($sqlupdate); 
      $rs->execute(array(':chfodid'=>$fodid[$i], 
          ':chcount'=>$quantity[$i])); 
      echo 'Order updated';      
     } else {   
      $rs = $conn->prepare($sql); 
      $rs->execute(array(':foodid'=>$fodid[$i], 
          ':count'=>$quantity[$i])); 
      echo 'Order Saved'; 
     }   

    }       
    $conn=null; 
}catch (PDOException $e) { 
    print "Error!: " . $e->getMessage() . "<br/>"; 
    die(); 
} 
+0

只是一個說明:一個聲明只能一次準備。因此,準備一次,並給所有stmts和可讀的名稱,如'$ selectStmt' – JustOnUnderMillions

+0

你的混凝土問題在哪裏? – JustOnUnderMillions

+0

另一個說明,請使用['insert on duplicate update'](https://dev.mysql.com/doc/refman/5.7/en/insert-on-duplicate.html)聲明 – hassan

回答

0

我解決我的問題是語法錯誤 「: chkfoodid'只是刪除單引號:chkfoodid