12

我有这个完全相同的代码在另一台服务器上运行良好:

$mysqli_Cxn = new mysqli($SQL_HOST,$SQL_USER,$SQL_PASS,$SQL_DB);
if($mysqli_Cxn->connect_errno){
echo 'Unable to connect!!';
exit();
}

$userID=12345;
$userFirstName = 'Charley';
$userLocale = 'en_US';

$sql = "UPDATE userProfile SET userFirstName=?, userLocale=? WHERE id=?";

if($stmt = $mysqli_Cxn->prepare($sql)){
 if(!$stmt->bind_param('ssi',$userFirstName,$userLocale,$userID)){
  echo "<br/><br/>Binding parameters failed: (" . $stmt->errno . ") " . $stmt->error;
 }
 if($stmt->execute()){
  totalAffected=$stmt->affected_rows;
  if($totalAffected>=1){
   echo '<br/><br/>UPDATE OK: Affected rows = '. $totalAffected;
  }
 }else{
  echo "Execute failed: (" . $stmt->errno . ") " . $stmt->error;
 }
}
$stmt->close();

该代码给了我以下输出:执行失败:(1210)mysql_stmt_execute 的参数不正确

如果我改变这两行:

$sql = "UPDATE userProfile SET userFirstName=?, userLocale=? WHERE id=?";
$stmt->bind_param('ssi',$userFirstName,$userLocale,$userID);

对此:

$sql = "UPDATE userProfile SET userFirstName=?, userLocale='en_US' WHERE id=12345";
$stmt->bind_param('s',$userFirstName);

...然后更新成功,我没有收到任何错误。

有谁知道为什么我不能在这段代码中绑定多个参数?

我让这段代码在 Centos 4.9、PHP 5.3.3、MySQL 5.0.91/5.0.91-community-log 上完美运行

我需要在我当前的服务器 Centos 6.2、PHP 5.3.10、MySQL 5.0.95-community-log 上运行它

4

4 回答 4

3

我做了一些研究,结合您的 GCC 版本和您使用的优化标志,这似乎是 MySQL 源代码中报告的错误。如果您无法更改 MySQL 版本,请尝试在您的 CFLAGS 中添加 -fno-strict-aliasing 重新编译 MySQL。

有关更多详细信息,请参阅http://bugs.mysql.com/bug.php?id=48284

于 2012-04-09T16:56:49.140 回答
1

关于这个问题的最后说明。

我使用以下配置启动并运行了一个新服务器:

PHP 5.3.10
MySQL 5.1.61-cll

我使新服务器能够接受外部连接并在第一台服务器上测试了相同的代码(这次将“localhost”替换为我的新服务器的 IP)。

当我尝试在查询中使用多个参数时,它给了我完全相同的错误。

最后我在新服务器上测试了代码(使用多参数查询),它没有任何问题。

我的逻辑可能有问题,但我想问题出在 mysqli 的客户端版本上:

第一台服务器:

printf("Client library version: %d\n", mysqli_get_client_version());
//Output:
//Client library version: 50095 

新服务器:

printf("Client library version: %d\n", mysqli_get_client_version());
//Output:
//Client library version: 50161 

所以我可以提出两个建议:

  1. 帮自己一个忙,去PDO
  2. 想要/必须只使用 mysqli?确保您的服务器的 mysqli 客户端版本不是50095

感谢大家的评论/帮助!

PS:我正在使用带有 CPanel 的 VPS 服务器。我尝试在第一台服务器上使用 WHM 中的 EasyApache 重新编译 mysqli 客户端 - 并且完全是一个菜鸟 - 我想我坚持使用通过 Cpanel 提供的版本(直到我的下一次升级)。

于 2012-04-21T05:39:29.967 回答
0

我建议你明确地$userID转换为整数并重新测试它是否仍然失败。

由于 PHP 变量默认是变量,因此在将非字符串(在本例中为整数)绑定到查询时可能会遇到问题。

你能试一下吗:

$sql = "UPDATE userProfile SET userFirstName=?, userLocale=? WHERE id=?";
$stmt->bind_param('ssi',$userFirstName,$userLocale,(int)$userID);
于 2012-04-10T06:43:12.863 回答
0

我遇到了完全相同的问题。

(绑定参数不接受多个参数)

我使用这个命令的mysql版本:

printf ("Client library Version:% d \ n", mysqli_get_client_version ());

是:50094

50095 版本在此问题上存在争议:

https://www.liketly.com/forum/thread/27005/mysqli-bind_param-giving-error-1210-incorrect-arguments-to-mysql_stmt_execute/

将 PHP 5.4 更新到 5.6(在共享服务器上)后,mysql 版本也更新了,问题消失了。

我的新mysql版本是50011

于 2015-12-19T23:56:23.987 回答