0

我有一个积分系统,就像人们可以升级到 [PRO1] 用户一样。每个人的权限(pro1、pro2、user)都存储在我的 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

4

3 回答 3

1

order by right必须order by rights在第二个代码块的第一个查询中。

于 2012-12-13T20:25:41.633 回答
1

该查询不会告诉您最后升级到的用户是谁rights='[PRO1]'。那只是一个字符串字段。您需要某种在用户权限更改时更新的日期时间/时间戳字段,您可以通过它进行排序。

您也不需要进行 2 次查询。您有两个查询在做完全相同的事情。

做就是了:

SELECT username FROM users WHERE rights='[PRO1]' ORDER BY update_timestamp DESC LIMIT 1

update_timestamp权限更改时更新的字段在哪里。

于 2012-12-13T20:27:16.957 回答
0

原因是因为right是一个使用过的关键字,你需要一个回击来解决这个问题:;

喜欢 :

select * from `users` WHERE rights='[PRO1]' order by `rights` DESC limit 1
于 2012-12-13T20:23:14.893 回答