目录
回复讨论(解决方案)
首页 后端开发 php教程 mysqli查询数据始终为null

mysqli查询数据始终为null

Jun 23, 2016 pm 01:33 PM

代码如下,测试好多遍,始终不知道原因,Sql语句在Navicat里边有查询结果,大家帮我看看:
function db_connect(){
    $db=new mysqli("127.0.0.1", "root","admin159753","51dm","utf8");
    $db->set_charset('utf8');
    if (!$db) {
        echo "Cloud not connect to database";
    } else {
        return $db;
    }
}

$DB=db_connect(); 
$type="首页驻站作品";
$query = "select * from picture where type='首页驻站作品' order by chage_date desc";
$rs = $DB->query($query);

if (mysqli_num_rows($rs)==0) {
    echo "num rows: 0";
}

if ($rs) {
    echo "rs";
} else {
    echo "查询失败";
}
?>


回复讨论(解决方案)

你没写出查询结果 能出结果才怪

运行后页面显示了什么?

while( $row=mysqli_fetch_assoc($rs)){
var_dump($row);
}

他没执行查询,

$rs = $DB->query($query);
这是什么?

他没执行查询,

使用 mysqli_connect试试 

你没写出查询结果 能出结果才怪


$rs的值始终是null,我怀疑是环境的问题

运行后页面显示了什么?


num rows:0 查询失败

运行后页面显示了什么?


一个老古董程序,10年写的,服务器几年没人维护了

你大意了(我也粗心没注意)
你用 mysqli 类连接的数据库和进行的查询,却在用 mysqli 函数进行检查(mysqli_num_rows)当然是不行的!

他没执行查询,


$DB->query($query);
这句已经查询了,用的mysqli方式

你大意了(我也粗心没注意)
你用 mysqli 类连接的数据库和进行的查询,却在用 mysqli 函数进行检查(mysqli_num_rows)当然是不行的!



if (mysqli_num_rows($rs)==0) {
     echo "num rows: 0";
 }
这句是我测试随便加的,去掉这句也没关系,$rs仍然是为null,也就是$rs = $DB->query($query)这句查出来的结果始终为null,不知道为什么

$rs = $DB->query($query);
if(!$rs){
printf("Errormessage: %s\n", $mysqli->error);
}

看看有什么错。

$query = "select * from picture where type='首页驻站作品' order by chage_date desc";
如果是同样的查询语句,很有可能是字符集的原因。
你php的文件编码是utf-8的么

if ($rs) {
    echo "rs";
} else {
    echo "查询失败"  .  $db->error;
}

 $db=new mysqli("127.0.0.1", "root","admin159753","51dm","utf8");

$query = "select * from picture where type='首页驻站作品' order by chage_date desc";
$rs =  $DB->query($query);

我是初学者,但是看出了很多问题(我说错了不要骂我啊): 

$db=new mysqli("127.0.0.1", "root","admin159753","51dm","utf8");

mysqli 给的参数给多了吧!数据库连接会出问题的!

 if (!$db) {
        echo "Cloud not connect to database";
    } else {
        return $db;
    }

用$db作判断条件,也有问题吧,mysqlil连接无论失败或者成功,都会返个对象给你吧!$db总为真!不信的话,你在return $db;上面加个 echo "ok"; 

而且mysqli 类是不是应该用 $db->errno 来判断数据库连接是否成功?

所以,你的第一步连接数据库那里就有问题,当然查询不到东西!

$query = "select * from picture where type='首页驻站作品' order by chage_date desc";
如果是同样的查询语句,很有可能是字符集的原因。
你php的文件编码是utf-8的么


我还特意改成utf-8了,还是不行,重启服务器后,金山卫士发现病毒无数,好几年没人打理了

if ($rs) {
    echo "rs";
} else {
    echo "查询失败"  .  $db->error;
}



看了php的版本,居然是5.2.13……这么旧



看来还是得细心啊,源文件参数没配对,正解  

谢谢大家 

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门文章

两个点博物馆:邦格荒地地点指南
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章

两个点博物馆:邦格荒地地点指南
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
3 周前 By 尊渡假赌尊渡假赌尊渡假赌

热门文章标签

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

11个最佳PHP URL缩短脚本(免费和高级) 11个最佳PHP URL缩短脚本(免费和高级) Mar 03, 2025 am 10:49 AM

11个最佳PHP URL缩短脚本(免费和高级)

在Laravel中使用Flash会话数据 在Laravel中使用Flash会话数据 Mar 12, 2025 pm 05:08 PM

在Laravel中使用Flash会话数据

6个额外的技能,每个PHP开发人员都应该拥有 6个额外的技能,每个PHP开发人员都应该拥有 Feb 28, 2025 am 10:52 AM

6个额外的技能,每个PHP开发人员都应该拥有

了解PHP中的阵列 了解PHP中的阵列 Feb 28, 2025 am 10:53 AM

了解PHP中的阵列

简化的HTTP响应在Laravel测试中模拟了 简化的HTTP响应在Laravel测试中模拟了 Mar 12, 2025 pm 05:09 PM

简化的HTTP响应在Laravel测试中模拟了

构建具有Laravel后端的React应用程序:第2部分,React 构建具有Laravel后端的React应用程序:第2部分,React Mar 04, 2025 am 09:33 AM

构建具有Laravel后端的React应用程序:第2部分,React

在Codecanyon上的12个最佳PHP聊天脚本 在Codecanyon上的12个最佳PHP聊天脚本 Mar 13, 2025 pm 12:08 PM

在Codecanyon上的12个最佳PHP聊天脚本

php中的卷曲:如何在REST API中使用PHP卷曲扩展 php中的卷曲:如何在REST API中使用PHP卷曲扩展 Mar 14, 2025 am 11:42 AM

php中的卷曲:如何在REST API中使用PHP卷曲扩展

See all articles