PHP与MysqL这对黄金搭档配合的相当默契,但偶尔也会遇到一些小需求不知道该怎么做,例如今天要谈到的:如何判断sql语句查询的结果集是否为空!
我们以查询学生信息为例,来看看究竟如何实现我们的需求。
首先,来看看我们的数据表“student”中所存储的数据是个什么样子;
我们来看看SQL查询功能代码,我们要将年龄为16岁的学生信息都查出来;
PHP代码如下:
/**
* @param
* @arrange (512.笔记) jb51.cc
**/
<?PHP
$sql = "select * from `student` where `age`='16';";
$rows = MysqL_query($rs);
?>
<ul>
<?PHP
while($rows=MysqL_fetch_array($rs)){
?>
<li>姓名:<?PHP echo $rows['stuname'];?></li>
<li>性别:<?PHP echo $rows['gender'];?></li>
<li>年龄:<?PHP echo $rows['age'];?></li>
<li>年级:<?PHP echo $rows['grade'];?></li>
<li>班级:<?PHP echo $rows['class'];?></li>
<?PHP
}
?>
</ul>
// 来自:编程之家 jb51.cc(jb51.cc)
以上便是查询功能,当结果集不为空时,一切正常,当数据集为空时,会得到一个空白的ul标签,作为使用者却不知道为什么没有得到数据,此时我们需要给用户一个提示信息,那么我们就需要判断这个结果集是否为空!
如何才能判断结果集是否为空呢,有下面两个方法:
PHP代码如下:
/**
* @param
* @arrange (512.笔记) jb51.cc
**/
//方法一 获取select结果集的行数
$rows=MysqL_query("select * from `student` where `age`='16';");
if (MysqL_num_rows($rows) < 1){
echo '查询无数据!';
}
//方法二 返回上一次操作受影响的行数
$rows=MysqL_query("select * from `student` where `age`='16';");
if(!MysqL_affected_rows()){
echo '查询无数据!';
}
// 来自:编程之家 jb51.cc(jb51.cc)
知道了方法,那么把方法套到我们的代码中看看效果吧PHP代码如下:
/**
* @param
* @arrange (512.笔记) jb51.cc
**/
//方法一
<?PHP
$sql = "select * from `student` where `age`='16';";
$rows = MysqL_query($rs);
?>
<ul>
<?PHP
if (MysqL_num_rows($rs) < 1){
echo '查询无数据!';
}else{
while($rows=MysqL_fetch_array($rs)){
?>
<li>姓名:<?PHP echo $rows['stuname'];?></li>
<li>性别:<?PHP echo $rows['gender'];?></li>
<li>年龄:<?PHP echo $rows['age'];?></li>
<li>年级:<?PHP echo $rows['grade'];?></li>
<li>班级:<?PHP echo $rows['class'];?></li>
<?PHP
}
}
?>
</ul>
//方法二
<?PHP
$sql = "select * from `student` where `age`='16';";
$rows = MysqL_query($rs);
?>
<ul>
<?PHP
if(MysqL_affected_rows()){
while ($rows=MysqL_fetch_assoc($rs)){
?>
<li>姓名:<?PHP echo $rows['stuname'];?></li>
<li>性别:<?PHP echo $rows['gender'];?></li>
<li>年龄:<?PHP echo $rows['age'];?></li>
<li>年级:<?PHP echo $rows['grade'];?></li>
<li>班级:<?PHP echo $rows['class'];?></li>
<?PHP
}
}else {
echo "查无数据!";
}
?>
</ul>
// 来自:编程之家 jb51.cc(jb51.cc)