PHP-致命错误:Can';t在写入上下文中使用方法返回值


PHP - Fatal error: Can't use method return value in write context

嘿,伙计们,请帮帮我,我在尝试连接数据库时遇到了这个错误。

致命错误:在第20行的C:''wamp''www''ipsem6''include''membersite_config.php中,无法在写入上下文中使用函数返回值

下面是我的代码`

$host="localhost";
$username="root";
$password="";
$link=mysqli_connect($host,$username,$password,"a8172058_portal");
if(isset($_POST["submit"]))
 {
    $name=$_POST["name"];
    $email=$_POST["email"];
    $username=$_POST["username"];
    $pass=$_POST["password"];
    $contactno=$_POST["contact1"];
    $cont2=$_POST["contact2"];
    $dob=$_POST["date"];
    $role=$_POST["rle"];
    $gender=$_POST["s"];
    $qry="insert users          values('$name','$email','$username','$pass','$contactno','$cont2','$dob','$role','$gender')";
    $res=mysqli_query($link,$qry);
    if(mysqli_query_rows($link)=false)
    {
        echo 'you have registered successfully';
    }
    else
    {
        echo 'registration failed';
    }

?>` 

我检查了很多解决方案,但无法理解,因为我在数据库编程方面不太好。。!请帮我把它单独列出,因为我明天必须提交我的项目

if(mysqli_query_rows($link)=false)

您正在尝试将值false分配给此处的函数返回值。

PHP中的比较运算符是==

您必须使用以下代码:

 if(mysqli_query_rows($link)){}
if(mysqli_query_rows($link)==false) 

而不是:

if(mysqli_query_rows($link)=false)

==用于检查值(比较运算符),=是赋值运算符。

中的赋值

if(mysqli_query_rows($link)=false)

没有意义;它应该是服从类型的比较运算符CCD_ 4。

此外,没有这样的函数mysqli_query_rows()。也许您在寻找mysqli_fetch_row()或mysqli_num_rows()。(但要注意,这些函数操作的是结果标识符,而不是数据库连接标识符。)

您正在执行INSERT操作,因此将没有要获取的数据。相反,查询本身会在失败时返回false,因此正确的表示应该是:

if($res!==false)

(注意,我使用了不等式运算符,因为if的结果是成功。)无论如何,成功和错误应该取决于对输入的测试,而不是插入操作本身。

最后但同样重要的是,您的脚本容易受到SQL注入的攻击。