Heim > Artikel > Backend-Entwicklung > mysqli查询数据始终为null
代码如下,测试好多遍,始终不知道原因,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试试
你没写出查询结果 能出结果才怪
运行后页面显示了什么?
运行后页面显示了什么?
你大意了(我也粗心没注意)
你用 mysqli 类连接的数据库和进行的查询,却在用 mysqli 函数进行检查(mysqli_num_rows)当然是不行的!
他没执行查询,
你大意了(我也粗心没注意)
你用 mysqli 类连接的数据库和进行的查询,却在用 mysqli 函数进行检查(mysqli_num_rows)当然是不行的!
$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的么
if ($rs) {
echo "rs";
} else {
echo "查询失败" . $db->error;
}
谢谢大家