首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 网站开发 > PHP >

如何知道查询结果是0条记录

2012-04-10 
怎么知道查询结果是0条记录我想在插入记录之前先查询数据库里面有没有这条记录,实际上我数据库表里面并没

怎么知道查询结果是0条记录
我想在插入记录之前先查询数据库里面有没有这条记录,实际上我数据库表里面并没有满足certificatetype='hdfj'的记录
$sql="select * from customers where certificatetype='hdfj'";
$result=mysql_query($sql);
if(!$result)
die mysql_error();
else
{
//这儿应该怎么做才知道数据库里面有没有这条记录呢?
//为什么我下面这两条语句都会输出1呢?
  echo count(mysql_fetch_row($result));
  echo count($result);
  
}

[解决办法]
mysql_num_rows()获取结果集的行数。
之所以返回1,是由于count()的特殊。 如你所说数据库没有这条记录的话,mysql_fetch_row($result) 返回的就应该是false。而
$result = count(false);
// $result == 1
[解决办法]
echo mysql_num_rows($result) //返回查询的行数。
[解决办法]

探讨
mysql_num_rows()获取结果集的行数。
之所以返回1,是由于count()的特殊。 如你所说数据库没有这条记录的话,mysql_fetch_row($result) 返回的就应该是false。而
$result = count(false);
// $result == 1

[解决办法]
PHP code
//这儿应该怎么做才知道数据库里面有没有这条记录呢?echo mysql_affected_rows();//或者echo mysql_num_rows($result);
[解决办法]
count()函数里第一个参数应该是array or object."If var is not an array or ......,1 will be returned."参考PHP手册:
http://cn2.php.net/manual/en/function.count.php
[解决办法]
mysql_num_rows 是计数
mysql_fetch_array he mysql_fetch_rows是返回一个数组

热点排行