我有一个点系统,就像人们可以升级到[PRO1]用户一样。每个人的权利(pro1,pro2,用户)都存储在我的mysql用户表中。但是我想做一点饲料,显示最新的升级到[PRO1]。升级代码:
$insert = "UPDATE `users` SET `points` = (`points`-50) WHERE `username` = '".$username."' and points > 50";
mysql_query($insert);
if (mysql_affected_rows() > 0)
{
// other codes
$insert = "UPDATE users SET rights=' [PRO1]' WHERE `username` = '".$username."'";
mysql_query($insert);
header('location: succesupgrade.php');
}else{
echo "You don't have enough points";
}
?>
升级代码工作正常(只是因为我需要添加一个时间/日期。而且我希望“'用户名'最后升级到[PRO1]”的代码在此代码中:
<?php
require("dbc.php");
$query = mysql_query("select * from users WHERE rights='[PRO1]' order by right DESC limit 1") or die(mysql_error());
while($array = mysql_fetch_array($query)) {
echo "{$array['username']}<br>";
}
?>was the last to upgrade to:
<?php
require("dbc.php");
$query = mysql_query("select * from users WHERE rights='[PRO1]' order by rights DESC limit 1") or die(mysql_error());
while($array = mysql_fetch_array($query)) {
echo "{$array['rights']}<br>";
}
?>
但是该代码给了我这个错误:You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'DESC limit 1' at line 1
答案 0 :(得分:1)
order by right
必须为order by rights
。
答案 1 :(得分:1)
该查询无法告诉您最后一位升级到rights='[PRO1]'
的用户。那只是一个字符串字段。您需要某种日期时间/时间戳字段,该字段在用户权限更改时更新,您可以通过该字段进行排序。
您也不需要进行2次查询。你有两个查询做同样的事情。
只是做:
SELECT username FROM users WHERE rights='[PRO1]' ORDER BY update_timestamp DESC LIMIT 1
其中update_timestamp
是权限更改时更新的字段。
答案 2 :(得分:0)
原因是因为right
是一个二手关键字,你需要一个后退来解决这个问题:;
喜欢:
select * from `users` WHERE rights='[PRO1]' order by `rights` DESC limit 1