应天论坛

 找回密码
 参与我们

QQ登录

只需一步,快速开始

搜索
查看: 930|回复: 0

php如何判断SQL语句的查询结果是否为空?

[复制链接]

276

主题

303

帖子

3197

积分

管理员

湘南小侠客

Rank: 9Rank: 9Rank: 9

积分
3197

优质服务勋章论坛元老

QQ
发表于 2017-6-23 09:39:22 | 显示全部楼层 |阅读模式
PHP与mysql这对黄金搭档配合的相当默契,但偶尔也会遇到一些小需求不知道该怎么做,例如今天要谈到的:如何判断sql语句查询的结果集是否为空!

我们以查询学生信息为例,来看看究竟如何实现我们的需求。

首先,来看看我们的数据表“student”中所存储的数据是个什么样子:

id  stuname  gender  age  grade  class

1  张三     男    16  17    3

2  李四     男    15  18    2

3  王美丽    女    16  17    5

我们来看看sql查询功能代码,我们要将年龄为16岁的学生信息都查出来;

[mw_shl_code=php,true]<?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>[/mw_shl_code]


以上便是查询功能,当结果集不为空时,一切正常,当数据集为空时,会得到一个空白的ul标签

作为使用者却不知道为什么没有得到数据,此时我们需要给用户一个提示信息,那么我们就需要判断这个结果集是否为空!

如何才能判断结果集是否为空呢,有下面两个方法:

[mw_shl_code=php,true]<?php
//方法一 获取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 '查询无数据!';
}
?>[/mw_shl_code]

知道了方法,那么把方法套到我们的代码中看看效果吧

[mw_shl_code=php,true]//方法一
<?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>[/mw_shl_code]

OK,大功告成,现在查不到数据的时候就会有提示了哦!
每次见你穿短裤打领带,还穿个拖鞋,下次再这样穿不要从我家门口过了!
http://gsh.yzqz.cn/CassettePlayer/index.html

天之道,损有余而补不足.人之道则不然,损不足以奉有余.孰能有余以奉天下,唯有道者.
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 参与我们

本版积分规则

QQ|Archiver|手机版|小黑屋|应天社区 ( 湘ICP备17015224号 )

GMT+8, 2024-12-22 19:53 , Processed in 0.078125 second(s), 28 queries .

Powered by Discuz!

© 2001-2017 Comsenz Inc.


免责声明:
本站所发布的第三方软件及资源(包括但不仅限于文字/图片/音频/视频等仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢某程序或某个资源,请支持正版软件及版权方利益,注册或购买,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To: admin@yzqz.cn

快速回复 返回顶部 返回列表