>  기사  >  백엔드 개발  >  PHP执行SQL后判断记录集不为空的语句

PHP执行SQL后判断记录集不为空的语句

WBOY
WBOY원래의
2016-06-06 20:15:20989검색

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

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.