gpt4 book ai didi

php - Mysqli multi_query 不执行所有查询

转载 作者:行者123 更新时间:2023-11-29 02:22:51 24 4
gpt4 key购买 nike

我正在使用 Mysqli 和 multi_query 在数据库表中更新或插入多行。当我在我的本地 MAMP 服务器上使用它们时它们工作正常,但当我将它们放到网上时它们就崩溃了。在远程服务器上,只执行了四个查询中的三个...

这两个环境都有 PHP 和 mysql 版本 5+,并包含“PHP 扩展名:mysqli”。我看到的唯一区别是 phpMyAdmin 版本。远程服务器有 3.5.6,我的本地 MAMP 服务器有 4.2.5。这会产生影响吗?

我当然要更改密码,所有变量都应该有效,因为它们在本地工作。

我不知所措......谢谢!

$mysqli = new mysqli("localhost", "root", "root", "database");
if ($mysqli->connect_errno) {
echo "Failed to connect to MySQL: (" . $mysqli->connect_errno . ") " . $mysqli->connect_error;
}
$sql = "INSERT INTO categories (id, name, descr) VALUES ('$id1', '$name1', '$descr1') ON DUPLICATE KEY UPDATE name='$name1', descr='$descr1';";
$sql.= "INSERT INTO categories (id, name, descr) VALUES ('$id2', '$name2', '$descr2') ON DUPLICATE KEY UPDATE name='$name2', descr='$descr2';";
$sql.= "INSERT INTO categories (id, name, descr) VALUES ('$id3', '$name3', '$descr3') ON DUPLICATE KEY UPDATE name='$name3', descr='$descr3';";
$sql.= "INSERT INTO categories (id, name, descr) VALUES ('$id4', '$name4', '$descr4') ON DUPLICATE KEY UPDATE name='$name4', descr='$descr4';";

if (!$mysqli->multi_query($sql)) {
echo "Multi query failed: (" . $mysqli->errno . ") " . $mysqli->error;
}else{
echo("Succes.");
}
$mysqli->close()

更新:用单个查询替换查询确实可行,但在所有情况下都不太可行,并且需要大量重写...使用硬编码变量无济于事。

$sql2 = "INSERT INTO categories (id, name, descr)  VALUES ('$id1', '$name1', '$descr1'), ('$id2', '$name2', '$descr2'), ('$id3', '$name3', '$descr3'),('$id4', '$name4', '$descr4') 
ON DUPLICATE KEY UPDATE name=VALUES(name), descr=VALUES(descr)";

最佳答案

php.net 所示,使用“面向对象的样式”解决了这个问题。 .仍然不确定为什么我以前的方法只在本地有效但没关系,我们称之为固定。

/* execute multi query */
if ($mysqli->multi_query($query)) {
do {
/* store first result set */
if ($result = $mysqli->store_result()) {
while ($row = $result->fetch_row()) {
printf("%s\n", $row[0]);
}
$result->free();
}
/* print divider */
if ($mysqli->more_results()) {
printf("-----------------\n");
}
} while ($mysqli->next_result());
}

/* close connection */
$mysqli->close();

关于php - Mysqli multi_query 不执行所有查询,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28399946/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com