我的代码:
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'部落得到错误。这段代码有什么问题?
谢谢。
编辑:请编辑我的代码有什么问题。
答案 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)
修改下面提到的代码以适合您的应用
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";