php sqlsrv - 字段未更新

php sqlsrv - field not updating

我想更新 table 中的两个字段,称为请假,但是当我单击提交按钮时。

 <?php 
$stmt = $pdo->prepare('UPDATE dbo.[TABLE$Leave Request] dbo.[KPMG$Leave Request].supAprrove_date=?,dbo.[TABLE$Leave Request].supAprrove=? WHERE     dbo.[TABLE$Leave Request].id=?');
$stmt->execute(array($adate, $approve, $id));

$adate = $_POST['supAprrove_date'];
 $approve =$_POST['supAprrove'];
$id = $_POST['lid'];
 //$affected_rows = $stmt->rowCount();

?>
<form id="form1" name="form1" method="post" action="pending_leave.php">
  <label>
  <select name="supAprrove" id="supAprrove">
    <option value="1">Approve</option>
    <option value="2">Reject</option>
  </select>
  </label>
  <input name="supAprrove_date" type="hidden" id="supAprrove_date" value="<?php echo date('Y-m-d'); ?>" />
  <input type="hidden" name="lid" id="lid"  value="<?php echo $data['id'];  ?>"/>
  <label>
  <input type="submit" name="button" id="button" value="Submit" />
  </label>
</form>

创建 SQL UPDATE 语句的一种方法是

UPDATE table
SET column1 = expression1,
column2 = expression2,
...
[WHERE conditions];

示例:

UPDATE employees
SET last_name = 'Johnson'
WHERE employee_id = 10;

您正在使用准备好的语句,因此请将 'Johnson' 部分替换为“?”大功告成。

对于错误处理,您可以使用:

$dbh = new PDO($dsn, $user, $password, array(PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION));

PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION部分是抛出异常的关键。

关于 PDO 错误处理的更多信息:http://php.net/manual/en/pdo.error-handling.php