首頁 > 後端開發 > PHP問題 > php mysql怎麼判斷有沒有數據

php mysql怎麼判斷有沒有數據

藏色散人
發布: 2023-03-13 13:38:02
原創
3091 人瀏覽過

php mysql判斷有沒有資料的方法:1、建立一個PHP範例檔;2、取得select結果集的行數;3、傳回上一次運算受影響的行數;4、透過sql查詢功能代碼判斷有沒有資料即可。

php mysql怎麼判斷有沒有數據

本文操作環境: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`=&#39;16&#39;;";
$rows = mysql_query($rs);
?>
<ul>
    <?php
        while($rows=mysql_fetch_array($rs)){
    ?>
        <li>姓名:<?php echo $rows[&#39;stuname&#39;];?></li>
        <li>性别:<?php echo $rows[&#39;gender&#39;];?></li>
        <li>年龄:<?php echo $rows[&#39;age&#39;];?></li>
        <li>年级:<?php echo $rows[&#39;grade&#39;];?></li>
        <li>班级:<?php echo $rows[&#39;class&#39;];?></li>
    <?php
        }
    ?>
</ul>
登入後複製

 

以上便是查詢功能,當結果集不為空時,一切正常,當資料集為空時,會得到一個空白的ul標籤,

身為使用者卻不知道為什麼沒有得到數據,此時我們需要給使用者一個提示訊息,那麼我們就需要判斷這個結果集是否為空!

如何判斷結果集是否為空呢,有下面兩個方法:

<?php
//方法一 获取select结果集的行数
$rows=mysql_query("select * from `student` where `age`=&#39;16&#39;;");
if (mysql_num_rows($rows) < 1){
echo &#39;查询无数据!&#39;;
}
//方法二 返回上一次操作受影响的行数
$rows=mysql_query("select * from `student` where `age`=&#39;16&#39;;");
if(!mysql_affected_rows()){
    echo &#39;查询无数据!&#39;;
}
?>
登入後複製

知道了方法,那麼把方法套到我們的程式碼中看看效果吧

//方法一
<?php
$sql = "select * from `student` where `age`=&#39;16&#39;;";
$rows = mysql_query($rs);
?>
<ul>
    <?php
    if (mysql_num_rows($rs) < 1){
        echo &#39;查询无数据!&#39;;
    }else{
        while($rows=mysql_fetch_array($rs)){
    ?>
        <li>姓名:<?php echo $rows[&#39;stuname&#39;];?></li>
        <li>性别:<?php echo $rows[&#39;gender&#39;];?></li>
        <li>年龄:<?php echo $rows[&#39;age&#39;];?></li>
        <li>年级:<?php echo $rows[&#39;grade&#39;];?></li>
        <li>班级:<?php echo $rows[&#39;class&#39;];?></li>
    <?php
        }
    }
    ?>
</ul>
//方法二
<?php
$sql = "select * from `student` where `age`=&#39;16&#39;;";
$rows = mysql_query($rs);
?>
<ul>
    <?php
    if(mysql_affected_rows()){
        while ($rows=mysql_fetch_assoc($rs)){
    ?>
        <li>姓名:<?php echo $rows[&#39;stuname&#39;];?></li>
        <li>性别:<?php echo $rows[&#39;gender&#39;];?></li>
        <li>年龄:<?php echo $rows[&#39;age&#39;];?></li>
        <li>年级:<?php echo $rows[&#39;grade&#39;];?></li>
        <li>班级:<?php echo $rows[&#39;class&#39;];?></li>
    <?php
        }
    }else {
        echo "查无数据!";
    }
    ?>
</ul>
登入後複製

OK,大功告成,現在查不到數據的時候就會有提示了喔!

推薦學習:《PHP影片教學

以上是php mysql怎麼判斷有沒有數據的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板