php校验select是否为空,php如何判断sql不为空

php判断sql不为空的方法:首先通过sql查询功能代码查出信息;然后在php文件中通过“mysql_query”获取select结果集的行数;最后通过if语句判断sql查询结果即可。

b3b5aa75cff42eac3ebdcdbc651686c2.png

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);?>

  • 姓名:<?php echo $rows['stuname'];?>
  • 性别:<?php echo $rows['gender'];?>
  • 年龄:<?php echo $rows['age'];?>
  • 年级:<?php echo $rows['grade'];?>
  • 班级:<?php echo $rows['class'];?>

} ?>

以上便是查询功能,当结果集不为空时,一切正常,当数据集为空时,会得到一个空白的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 '查询无数据!';

}

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

$sql = "select * from `student` where `age`='16';";

$rows = mysql_query($rs);

?>

if (mysql_num_rows($rs) < 1){

echo '查询无数据!';

}else{

while($rows=mysql_fetch_array($rs)){

?>

姓名:<?php echo $rows['stuname'];?>性别:<?php echo $rows['gender'];?>年龄:<?php echo $rows['age'];?>年级:<?php echo $rows['grade'];?>班级:<?php echo $rows['class'];?>

}

}

?>

//方法二

$sql = "select * from `student` where `age`='16';";

$rows = mysql_query($rs);

?>

if(mysql_affected_rows()){

while ($rows=mysql_fetch_assoc($rs)){

?>

姓名:<?php echo $rows['stuname'];?>性别:<?php echo $rows['gender'];?>年龄:<?php echo $rows['age'];?>年级:<?php echo $rows['grade'];?>班级:<?php echo $rows['class'];?>

}

}else {

echo "查无数据!";

}

?>

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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值