• 技术文章 >后端开发 >PHP问题

    php mysql怎么判断有没有数据

    藏色散人藏色散人2021-10-26 09:20:03原创53

    php mysql判断有没有数据的方法:1、创建一个PHP示例文件;2、获取select结果集的行数;3、返回上一次操作受影响的行数;4、通过sql查询功能代码判断有没有数据即可。

    本文操作环境:Windows7系统、PHP7.1版、DELL G3电脑

    php mysql怎么判断有没有数据?php如何判断SQL语句的查询结果是否为空?

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

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

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

    id  stuname  gender  age  grade  class
    1  张三     男    16  17    3
    2  李四     男    15  18    2
    3  王美丽    女    16  17    5

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

    <?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标签,

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

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

    <?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 '查询无数据!';
    }
    ?>

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

    //方法一
    <?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,大功告成,现在查不到数据的时候就会有提示了哦!

    推荐学习:《PHP视频教程

    以上就是php mysql怎么判断有没有数据的详细内容,更多请关注php中文网其它相关文章!

    声明:本文原创发布php中文网,转载请注明出处,感谢您的尊重!如有疑问,请联系admin@php.cn处理
    专题推荐:php mysql
    上一篇:php 无法得到post怎么办 下一篇:php怎么删除输出之后最后一个字符
    大前端线上培训班

    相关文章推荐

    • php不支持mysql_query()吗• linux php怎么增加mysqli扩展• php怎么从mysql数据库中读出查询的数据• MySQL中什么是索引?索引存储模型浅析

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网