亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

PHP 多個查詢

PHP 多個查詢

PHP
MYYA 2023-10-15 15:05:31
是不是不能在不同的表上同時執行插入和刪除?或者我錯過了什么if(isset($_POST['update'])){    $id = $_POST['delete_id'];    $name= $_POST['edit_name'];    $name2= $_POST['edit_name2'];    $pic = $_POST['edit_pic'];    $contactnumber = $_POST['edit_contact'];    $address = $_POST['edit_address'];    $details = $_POST['edit_details'];    $query = "INSERT INTO tabletest (name,name2,pic,contact,address,details,) VALUES ('$name' , '$name2' , '$pic' , '$contactnumber' , '$address' , '$details')";    $query .= "DELETE FROM tabletest2 WHERE id='$id'";    if (mysqli_multi_query($connection, $query))    {        $_SESSION['success'] = "Data Updated";        header('Location: blankpage.php');    }     else     {        $_SESSION['status'] = "Error, Please try again";        header('Location: blankpage.php');    }    }
查看完整描述

1 回答

?
慕哥9229398

TA貢獻1877條經驗 獲得超6個贊

可以同時執行 DELETE 和 INSERT,但它們需要是單獨的查詢。如果您想讓這兩個操作都成為原子操作(都必須成功,否則都不應該執行),那么您需要使用DB transactions。

要將 2 個查詢作為單個原子語句執行,您可以執行以下操作:

mysqli_report(MYSQLI_REPORT_ERROR | MYSQLI_REPORT_STRICT);

$connection = new mysqli();

$connection->set_charset('utf8mb4'); // always set the charset


if (isset($_POST['update'])) {

? ? $id = $_POST['delete_id'];

? ? $name = $_POST['edit_name'];

? ? $name2 = $_POST['edit_name2'];

? ? $pic = $_POST['edit_pic'];

? ? $contactnumber = $_POST['edit_contact'];

? ? $address = $_POST['edit_address'];

? ? $details = $_POST['edit_details'];


? ? // start transaction

? ? $connection->begin_transaction();


? ? try {

? ? ? ? $stmt = $connection->prepare('INSERT INTO tabletest (name,name2,pic,contact,address,details,) VALUES (?,?,?,?,?,?)');

? ? ? ? $stmt->bind_param('ssssss', $name, $name2, $pic, $contactnumber, $address, $details);

? ? ? ? $stmt->execute();


? ? ? ? $stmt = $connection->prepare('DELETE FROM tabletest2 WHERE id=?');

? ? ? ? $stmt->bind_param('s', $id);

? ? ? ? $stmt->execute();

? ??

? ? ? ? // save data and end transaction

? ? ? ? $connection->commit();


? ? ? ? $_SESSION['success'] = "Data Updated";

? ? ? ? header('Location: blankpage.php');

? ? } catch (Exception $e) {

? ? ? ? $connection->rollback();

? ? ? ? $_SESSION['status'] = "Error, Please try again";

? ? ? ? header('Location: blankpage.php');

? ? }

}


查看完整回答
反對 回復 2023-10-15
  • 1 回答
  • 0 關注
  • 125 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號