IF 语句仅显示 1 个变量,而不考虑结果


IF statement displaying only 1 variable regardless of results

我有一个网站,用户可以在其中加入群组并发布与该群组相关的主题,我遇到了一个问题,无论用户结果如何,即使在数据库中没有记录的测试帐户上,它也只显示"成员",有人可以解释一下我做错了什么,谢谢。

<?php
$id = $_GET['gid'];
$user = $_SESSION['user_id'];
$iropen = "SELECT * FROM `group_users` WHERE user_id='$user' AND group_id='$id'"; 
$resultg = mysql_query($iropen);
$rows = mysql_fetch_array($resultg);
if ($rows['accepted'] = 1) {
    echo 'member';
} else {
    echo 'pending';
}
if ($resultg < 1) {
    echo 'join';
}
?>
if ($rows['accepted'] = 1) {

这里需要两==

if ($rows['accepted'] == 1) {

PHP 的运算符参考,如果需要的话:http://www.php.net/manual/en/language.operators.php

@vinodadhikary的意思是,在第一个 IF 子句中,你有一个等号而不是双等号。 它应该是:如果 ($rows["已接受"] == 1)...

<?php
    $id = $_GET['gid'];
    $user = $_SESSION['user_id'];
    $iropen = "SELECT * FROM `group_users` WHERE user_id='$user' AND group_id='$id'"; 
    $resultg = mysql_query($iropen);
    $rows = mysql_fetch_array($resultg);
    $num_results = mysql_num_rows($resultg);

    if ($num_results < 1) {
        echo "join";
    } else if ($rows['accepted'] == 1) {
        echo "member";
    } else {
        echo "pending";
    }
?>

试试这个

<?php
$id = $_GET['gid'];
$user = $_SESSION['user_id'];
$iropen = "SELECT * FROM `group_users` WHERE user_id='".$user."' AND group_id='".$id."'"; 
if($resultg = mysql_query($iropen)){
     $rows = mysql_fetch_array($resultg)
}
if (mysql_num_rows($resultg) < 1) {
    echo 'join';
}else if ($rows['accepted'] == 1) {
    echo 'member';
} else {
    echo 'pending';
}
?>