PHP $stmt->num_rows 不适用于准备好的语句[重复]

Posted

技术标签:

【中文标题】PHP $stmt->num_rows 不适用于准备好的语句[重复]【英文标题】:PHP $stmt->num_rows doesnt work by prepared statements [duplicate] 【发布时间】:2017-03-13 13:03:24 【问题描述】:

我想检查if ($numRows >= 1) 然后它应该返回一些东西。

当我使用$con->mysql("QUERY") 时,它可以工作。

但是当我使用$stmt = $con->prepare("QUERY")时,它不起作用。

有人知道吗?

工作方法

<?php
if ($result = $con->query("SELECT username FROM users WHERE username = 'test'")) 
    $numRows = $result->num_rows;

    echo $numRows;

?>

结果:1​​

无效的方法

<?php
$name = 'test';

$stmt = $con->prepare("SELECT username FROM users WHERE username = ?");
$stmt->bind_param('s', $name);

$name = 'test';

$stmt->execute();

$numRows = $stmt->num_rows;

echo $numRows;
?>

结果:0

【问题讨论】:

WHERE username = 'tst' 并且您正在分配 $name = 'test'; 或者这只是一个错字? @Fred-ii- 必须编辑一些东西,确实编辑过。你现在可以检查一下吗? 您需要存储和绑定结果。查看它关闭的重复问题中的答案(它包含一个准备好的语句方法)和 Rajdeep 的答案。 【参考方案1】:

您需要在调用-&gt;num_rows() 方法之前传输SELECT 查询的结果集。

// your code    

$stmt->execute();
$stmt->store_result();  
$numRows = $stmt->num_rows;

echo $numRows;

这是参考:

http://php.net/manual/en/mysqli.store-result.php

【讨论】:

以上是关于PHP $stmt->num_rows 不适用于准备好的语句[重复]的主要内容,如果未能解决你的问题,请参考以下文章

PHP预处理 CURD

在 php 中使用 PDO 类获取 num_rows 的问题

如何使用准备好的语句选择 IP 地址

PHP负时间计算

如何在 PHP 8 中修复这个动态 SQL 查询功能?

PDO/PHP - 检查行是不是存在