嘿,伙计们,请帮帮我,我在尝试连接数据库时遇到了这个错误。
致命错误:在第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注入的攻击。