简单的mysql查询if语句


PHP Easy mysql query if-statement

我的代码:

mysql_connect(SQL_SERVER, SQL_USER, SQL_PASS);
mysql_select_db(SQL_DB);
$result = mysql_query("SELECT id FROM ".TB_PREFIX."users WHERE tribe = '2'");
if (!$result) {
die("Tribe Error");
}

在这段代码中,所有用户部落都得到错误。但我想只有'2'部落得到错误。这段代码有什么问题?

谢谢。

编辑:请在我的代码上编辑什么是错误的,请。

您正在检查查询是否返回错误,而不是查询是否返回1(或更多…)行,这可能是您想要的。返回0行的查询仍然是有效的查询。

除此之外,你应该切换到PDO(或mysqli)和准备语句绑定变量。

在PDO中,您可能可以获得返回行数rowCount(),查看手册以了解如何将代码重写为PDO的更多详细信息。

我为你找到了这个:http://php.net/manual/en/mysqli.query.php

在这里你可以学习如何使用mysqli

下面的代码,你可以修改为你自己的

编辑:这不是正确的方法,但试试这个

mysql_connect(SQL_SERVER, SQL_USER, SQL_PASS);
mysql_select_db(SQL_DB);
$result = mysql_query("SELECT id FROM ".TB_PREFIX."users WHERE tribe = 2");
$fetch = mysql_fetch_assoc($result);
if (count($fetch)<1) {
if (!$result) {
die("Tribe Error");
}
else{
var_dump($fetch);
}

Mysqli on PHP官网

修改下面提到的代码以适应您的应用程序

mysql_connect(SQL_SERVER, SQL_USER, SQL_PASS);
mysql_select_db(SQL_DB);
$result = mysql_query("SELECT id FROM ".TB_PREFIX."users WHERE tribe = 2") or die(mysql_error());
$fetch = mysql_num_rows($result);
if ($fetch > 0) {
    while($dets = mysql_fetch_assoc($result)){
        //displaying all info about current record
        var_dump($dets);
    }
}
else
    echo "No records";