PHP Easy mysql查询if语句

时间:2013-01-09 14:39:46

标签: php mysql if-statement row

我的代码:

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'部落得到错误。这段代码有什么问题?

谢谢。

编辑:请编辑我的代码有什么问题。

3 个答案:

答案 0 :(得分:0)

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

除此之外,您应该切换到PDO(或mysqli)并准备带有绑定变量的语句。

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

答案 1 :(得分:0)

我找到了你: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);
}

答案 2 :(得分:0)

Mysqli on PHP official site

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

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";