0

我有一个用户数据库,我希望管理员能够查看用户。我希望管理员能够按不同的字段对用户进行排序。(例如名字或姓氏)。

我的问题:
它不会排序。我正在尝试使用下拉框和提交按钮来做到这一点。我已经尝试过 phpMyAdmin 中的 Sql 以确保语句正确。我还添加了一个 or die 以确保它不是 mysql 错误。我没有收到任何错误,只是没有排序。我还尝试回显下拉菜单以确保将正确的值添加到变量中。

代码:HTML下拉

  <form action="View_users.php" enctype="multipart/form-data" name="sort" id="sort" method="post" align="right">
        <label>
          <select name="sortdropdown" id="sortdropdown">
          <option value="<?php echo $sortby; ?>"><?php echo $sortby; ?></option>
          <option value="name">First Name</option>
          <option value="surname">Surname</option>
          <option value="email">Email</option>
          <option value="signupdate">Date</option>
          </select>
        </label>
        <label>
             <input type="submit" name="button" id="button" value="Sort" />
        </label>
     </form>

逻辑:

$sortby = "";
if (!isset($_POST['sortdropdown'])) {
            $sortby = "surnname";
    }else{
    $sortby = mysql_real_escape_string($_POST['sortdropdown']);
    }
// This block grabs the whole list for viewing
$product_list = "";
$counter = 0;
$sql = mysql_query("SELECT * FROM users ORDER BY '$sortby' ASC")  or            die(mysql_error());

$productCount = mysql_num_rows($sql); // count the output amount
if ($productCount > 0) {
    while($row = mysql_fetch_array($sql)){ 
            $counter++;
             $id = $row["id"];
            $email = $row["email"];
            $name = $row["name"];
            $surname = $row["surname"];
            $lastlogin = $row["lastlogin"];
            $signupdate = $row["signupdate"];
            if (is_float($counter/2)) {$class = "#CCCCCC"; }
            else {$class = "white";}
            $product_list .= '<tr bgcolor="'.$class.'">
            <td>'.$surname.'</td>
            <td>'.$name.'</td>
            <td>'.$email .'</td>
            <td><a href="user.php?id=' . $id . '">View More</a></td></tr>';
     }
 } else {
$product_list = "There are no users in the system yet";
}

谢谢

4

1 回答 1

3

评论是正确的,您应该使用反引号 `$sortby` 而不是 '$sortby'

原因是 - 单引号用于包装 MySQL 中的值,这不是您想要的。您正在传递表格列的名称,因此您使用反引号,因为它们用于包装表格列名称。

于 2012-07-05T17:43:10.563 回答