我的代码:
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";