php 切换到 mysqli:num_rows 问题
声明:本页面是StackOverFlow热门问题的中英对照翻译,遵循CC BY-SA 4.0协议,如果您需要使用它,必须同样遵循CC BY-SA许可,注明原文地址和作者信息,同时你必须将它归于原作者(不是我):StackOverFlow 
原文地址: http://stackoverflow.com/questions/14917447/
Warning: these are provided under cc-by-sa 4.0 license.  You are free to use/share it, But you must attribute it to the original authors (not me):
StackOverFlow
php switching to mysqli: num_rows issue
提问by Hezerac
I recently started updating some code to MySQL improved extension, and have been successful up until this point:
我最近开始将一些代码更新为 MySQL 改进的扩展,并且一直成功到这一点:
// old code - works
$result = mysql_query($sql);
    if(mysql_num_rows($result) == 1){
    $row = mysql_fetch_array($result);
    echo $row['data'];
    }
// new code - doesn't work
$result = $mysqli->query($sql) or trigger_error($mysqli->error." [$sql]"); 
    if($result->num_rows == 1) {
    $row = $result->fetch_array();
    echo $row['data'];
    }
As shown I am trying to use the object oriented style. I get no mysqli error, and vardump says no data... but there definitely is data in the db table.
如图所示,我正在尝试使用面向对象的风格。我没有得到 mysqli 错误,而且 vardump 说没有数据……但 db 表中肯定有数据。
回答by Mr. Radical
Try this:
尝试这个:
<?php
// procedural style
$host = "host";
$user = "user";
$password = "password";
$database = "db";
$link = mysqli_connect($host, $user, $password, $database);
IF(!$link){
    echo ('unable to connect to database');
}
ELSE {
$sql = "SELECT * FROM data_table LIMIT 1";
$result = mysqli_query($link,$sql);
    if(mysqli_num_rows($result) == 1){
    $row = mysqli_fetch_array($result, MYSQLI_BOTH);
    echo $row['data'];
    }
}
mysqli_close($link);
// OOP style 
$mysqli = new mysqli($host,$user, $password, $database);
$sql = "SELECT * FROM data_table LIMIT 1";
$result = $mysqli->query($sql) or trigger_error($mysqli->error." [$sql]"); /* I have added the suggestion from Your Common Sence */
    if($result->num_rows == 1) {
    $row = $result->fetch_array();
    echo $row['data'];
    }
    $mysqli->close() ;
// In the OOP style if you want more than one row. Or if you query contains more rows.    
$mysqli = new mysqli($host,$user, $password, $database);
$sql = "SELECT * FROM data_table";
$result = $mysqli->query($sql) or trigger_error($mysqli->error." [$sql]"); /* I have added the suggestion from Your Common Sence */
    while($row = $result->fetch_array()) {
     echo $row['data']."<br>";
    }
    $mysqli->close() ;    
?>
回答by pine3ree
In PHP v 5.2 mysqli::num_rows is not set before fetching data rows from the query result:
在 PHP v 5.2 中 mysqli::num_rows 在从查询结果中获取数据行之前没有设置:
$mysqli = new mysqli($host,$user, $password, $database);
if ($mysqli->connect_errno) {
    trigger_error(sprintf(
        'Cannot connect to database. Error %s (%s)',
        $mysqli->connect_error,
        $mysqli->connect_errno
    ));
}
$sql = "SELECT * FROM data_table";
$result = $mysqli->query($sql);
// a SELECT query will generate a mysqli_result
if ($result instanceof mysqli_result) {
    $rows = array();
    while($row = $result->fetch_assoc()) {
        $rows[] = $row;
    }
    $num_rows = $result->num_rows; // or just count($rows);
    $result->close();
    // do something with $rows and $num_rows
} else {
    //$result will be a boolean
}
$mysqli->close() ;    
回答by Your Common Sense
As it was said, you're not checking for the errors.
Run all your queries this way
如前所述,您没有检查错误。
以这种方式运行所有查询
$result = $mysqli->query($sql) or trigger_error($mysqli->error." [$sql]");
if no errors displayed and var dumps are saying no data - then the answer is simple: your query returned no data. Check query and data in the table.
如果没有显示错误并且 var dumps 说没有数据 - 那么答案很简单:您的查询没有返回任何数据。检查表中的查询和数据。

