前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
社区首页 >专栏 >php如何判断SQL语句的查询结果是否为空?

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

作者头像
Yiiven
发布2022-12-15 11:17:50
发布2022-12-15 11:17:50
3.6K00
代码可运行
举报
文章被收录于专栏:怡文菌怡文菌
运行总次数:0
代码可运行

PHP与mysql这对黄金搭档配合的相当默契,但偶尔也会遇到一些小需求不知道该怎么做,例如今天要谈到的:如何判断sql语句查询的结果集是否为空!

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

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

id  stuname  gender  age  grade  class

1  张三     男    16  17    3

2  李四     男    15  18    2

3  王美丽    女    16  17    5

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

代码语言:javascript
代码运行次数:0
运行
复制
<?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>

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

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

代码语言:javascript
代码运行次数:0
运行
复制
 <?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 '查询无数据!';
}
?>

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

代码语言:javascript
代码运行次数:0
运行
复制
//方法一
<?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>

OK,大功告成,现在查不到数据的时候就会有提示了哦!

本文采用 「CC BY-NC-SA 4.0」创作共享协议,转载请标注以下信息:

原文出处:Yiiven https://cloud.tencent.com/developer/article/2193060

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2017-03-01 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档