PHP中mysqli_affected_rows与mysqli_num_rows的区别

PHP中mysqli_affected_rows与mysqli_num_rows的区别

今天写项目的时候用PHP搭了一个接口用于用户登录注册,登录我是这么写的

<?php
    $username = $_POST['username'];
    $password = $_POST['password'];
    $con = mysqli_connect('localhost','root','root','hubayi');
    $sql = "select * from users where name='$username' and password='$password'";
    $res = mysqli_query($con,$sql);
    $num = mysqli_num_rows($res);
    if($num > 0) {
        setcookie('login',1,time() + 60 * 60,'/',NULL,NULL);
        $arr = array('error' => 0,'data' => '成功');
    }else {
        $arr = array('error' => 1, 'data' => '失败','text' => $password);
    }
    echo json_encode($arr);
?>

在这个文件中我是用mysqli_num_rows获取受影响行数的,这个是没问题的,可以运行,于是我就比着葫芦画瓢,又写了一个注册

<?php
    $username = $_POST['username'];
	$password = $_POST['password'];
    $con = mysqli_connect('localhost','root','root','hubayi');
    $sql = "INSERT INTO users(name,password) VALUES('$username','$password')";
    $res = mysqli_query($con,$sql);
    $num = mysqli_affected_rows($res);
    if($num > 0) {
        $arr = array('error' => 0,'data' => '注册成功');
    } else {
        $arr = array('error' => 1,'data' => '注册失败');
    }
    echo json_encode($arr);
?>

然而这个代码就给我报错了,

mysqli_affected_rows() expects parameter 1 to be mysqli, bool given in <b>E:\phpstudy_pro\WWW\link\zhuce.php</b> on line <b>7</b><br />

就是这个错,以前我也遇到过,一般都是sql语句写错了,于是我研究一大会子也没看出来我这个sql语句哪错了,然后我就把mysqli_affected_rows()这个函数换成了mysqli_num_rows,于是又给我报这个错

mysqli_num_rows() expects parameter 1 to be mysqli_result

然后我就蒙圈了,你说我一个搞前端的,玩儿啥PHP啊,本着一个对代码的热爱还是把这个问题搞明白了。
mysqli_num_rows()这个函数只用于SELECT查询方法,而mysqli_affected_rows()函数是记录上一个sql语句对整个数据库的影响从而把受影响的数据个数返回,这个主要用于INSERT(插入)、UPDATE(替换)、DELETE(删除)。
重点来了,这两个函数所需参数不是一样的,我就吃了这个亏,传的都是sql语句执行的结果也就是上边代码的

$res = mysqli_query($con,$sql);

每次都传res,当然在mysqli_num_rows()是没问题的,因为mysqli_num_rows()需要就是这个结果,但是mysqli_affected_rows()就不一样了,他需要的是$con,也就是

$con = mysqli_connect('localhost','root','root','hubayi');

他需要一个mysql作为一个参数,就是这个数据库,他需要记录上一个sql语句对整个数据库的影响。以上就是我的理解,龙伏白威!
对前端感兴趣的小伙伴可以加我QQ:1627889159

上一篇:[已解决]您的PHP似乎没有安装运行WordPress所必需的MySQL扩展


下一篇:PHP基础之与MySQL那些事