OO MYSQLI num_rows总是= -1

时间:2016-09-06 23:32:16

标签: php html mysqli mysql-num-rows

我想检查用户名是否已经存在于我的注册页面的数据库中,为此我想我可以用输入用户名做一个选择查询,看看我得到了多少结果。但是,num_rows总是= -1我正在使用的测试用户名在数据库中两次,所以当我输入它时,它应该转到else并打印“此用户已经存在”。我也是mysqli的新手,所以如果你发现任何错误,我们将非常感谢您的反馈。

我的PHP在这里:

            <?php
            if(isset($_POST['submit'])){
                    $connection = new mysqli("localhost","username","password","DB");
                    if($connection->connect_errno){
                            echo "Failed to connecto MYSQL: (" . $connection->connect_errno . ") " . $connection-> connect_error;
                    }
                    else{
                            $username = $_POST['username'];
                            $password = $_POST['password'];
                            $password = password_hash($password, PASSWORD_DEFAULT);
                            $check_exist = $connection->prepare("SELECT username FROM users WHERE username = ?");
                            $check_exist->bind_param('s', $username);
                            $username = $connection->real_escape_string($username);
                            $check_exist->execute();
                            $check_exist->store_result();
                            $numRows = $check_exist->num_rows();
                            if($numRows = -1){
                                    echo "$numRows";
                                    $enter_user = $connection->prepare("INSERT INTO users (username, password) VALUES (?,?)");
                                    $enter_user->bind_param('ss', $username, $password);
                                    $enter_user->execute();
                                    $enter_user->store_result();
                                    $check_exist->close();
                                    $enter_user->close();
                                    $connection->close();
                            }
                            else{
                                    echo "This user already exists.";
                                    $check_exist->close();
                                    $connection->close();
                            }
                    }
            }
            ?>

对不起格式化,我在这里有点新......

1 个答案:

答案 0 :(得分:0)

行“if($ numRows = -1){”表示你想编码“if($ numRows == -1){”并将$ numRows值设置为-1。

您可以使用“if(!$ numRows){”。