Mysql选择where和order by

时间:2012-12-13 20:20:51

标签: php mysql database syntax

我有一个点系统,就像人们可以升级到[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

3 个答案:

答案 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