Maison >développement back-end >tutoriel php >PHP执行SQL后判断记录集不为空的语句
<code><?php $sql = "select * from mytable where name='$user_name'"; $result =mysql_query($sql,$con); if($result && mysql_num_rows($result)>0){ echo '<hr>记录集不为空!!!!!,说明已经有这个用户名了'; //执行更新操作 }else { //新增数据 } ?></code>
为什么明明有这个用户却不echo呢?
<code><?php $sql = "select * from mytable where name='$user_name'"; $result =mysql_query($sql,$con); if($result && mysql_num_rows($result)>0){ echo '<hr>记录集不为空!!!!!,说明已经有这个用户名了'; //执行更新操作 }else { //新增数据 } ?></code>
为什么明明有这个用户却不echo呢?
把$result去掉,它是一个资源类型resource,资源类型是无法进行布尔判断的
解决了吗?没解决的话你先打印一下$con,或者先把$result =mysql_query($sql,$con)里面的$con去掉试试,会默认打开上次连接,如果去掉可以,或者打印出来为空,说明你的连接对象没连接成功,检查一下初始化的时候给连接对象赋值成功了吗?没成功的原因,就是用户密码以及连接地址有问题,我自己是忘记$this->conn,直接mysql_connect了,然后后面调用$this->conn的就是null了。哈哈
也可以 !empty($result)