mysql查询没有收到正确的响应...或者其他什么

时间:2012-05-29 01:27:53

标签: php mysql

好的,所以我想做的事情应该通过下面的代码清楚, 对于我希望运行代码的每一行,如果标头为0,则运行第一个if语句,如果它运行第二个。

问题是,它设置它并不重要,它始终运行第二个if语句思维标题总是1,即使它不是。

测试我将echo(int)$ row [' header']添加到第二个if语句,并且对于每一行,它都回显为1.

任何人都知道如何让它做我想做的事情?

感谢您的帮助

我的PHP代码:

$result = mysql_query("SELECT * FROM LeftMenu_items");
while ($row = mysql_fetch_assoc($result))
{
    if ((int)$row['header'] = 0)
    {
        // echos value is on or not
        echo "<tr><td class='LeftMenu'><a href='" . $row['url'] . "'><b>" . $row['text'] . "</b></a></td></tr>\n";
    }
    else if ((int)$row['header'] = 1)
    {
        // header
        echo "<tr><td class='LeftMenu'>" . (int)$row['header'] . "<b>" . $row['text'] . "</b></td></tr>\n"; 
    }
    else echo "error displaying url";

我的表格如下:

structure:
id  int 
text    text    
url text    
Header  tinyint 

data:
1   Home    http://drudexflash.com/ 1
2   test1   http://text.com/    0
3   ttt blahz   1
4   nullnull    ass 0

1 个答案:

答案 0 :(得分:1)

问题是你要分配变量而不是比较。

if((int)$row['header'] = 0)

应该是

if ((int)$row['header'] == 0)

这不是一个不常见的错误,所以我有时会做的是切换值和变量的顺序,只是为了明确我正在比较和分配。

示例:

if (0 = (int)$row['header']) // even if you don't catch this as incorrect
                             // php will throw a 'parse error'
if (0 == (int)$row['header']) // correct, no error

一些有用的文档:http://www.php.net/manual/en/language.expressions.php http://www.php.net/manual/en/language.operators.comparison.php