1

我正在开发一个登录系统,并在其中实施了一个基本的管理员/级别系统。现在级别只是数字(1-9)。但是,我确实将它们标记为不同的名称或组。例如,1=会员,2=支持者等。我还有一个成员列表,其中显示了用户 ID、级别和上次活动的时间。但是它只显示 id 的数字(正如预期的那样)。我的问题是我将如何设置它以便数字最终在成员列表上显示名称/组?感谢高级,乔希

这是表格的代码:

<?php 

    include("include/session.php");


function displayUsers(){
   global $database;
   $q = "SELECT username,userlevel,email,timestamp "
       ."FROM ".TBL_USERS." ORDER BY userlevel DESC,username";
   $result = $database->query($q);
   /* Error occurred, return given name by default */
   $num_rows = mysql_numrows($result);
   if(!$result || ($num_rows < 0)){
      echo "Error displaying info";
      return;
   }
   if($num_rows == 0){
      echo "Database table empty";
      return;
   }
   /* Display table contents */
   echo "<table align=\"left\" border=\"1\" cellspacing=\"0\" cellpadding=\"3\">\n";
   echo "<tr><td><b>Username</b></td><td><b>Level</b></td><td><b>Last Active</b></td></tr>\n";
   for($i=0; $i<$num_rows; $i++){
      $uname  = mysql_result($result,$i,"username");
      $ulevel = mysql_result($result,$i,"userlevel");
      $time   = mysql_result($result,$i,"timestamp");

      echo "<tr><td>$uname</td><td>$ulevel</td><td>$time</td></tr>\n";
   }
   echo "</table><br>\n";
}
?> 

我的“数组”:

<?php echo $form->error("upduser"); ?>
<table>
<form action="adminprocess.php" method="POST">
<tr><td>
Username:<br>
<input type="text" name="upduser" maxlength="30" value="<?php echo $form->value("upduser"); ?>">
</td>
<td>
Level:<br>
<select name="updlevel">
<option value="1">Member
<option value="2">Supporter
<option value="3">Donor
<option value="4">VIP
<option value="5">Veteran
<option value="7">Co-Founder
<option value="8">Founder
<option value="9">Admin
</select>
</td>

我只需要帮助使用代码设置数组

4

1 回答 1

3

您应该在数据库中添加一个包含级别信息(id 和名称)的表,然后在查询中使用连接来获取包含用户详细信息的名称。

另一种在我看来不太可取的解决方案是对数组进行硬编码并显示相应的级别名称:

function displayUsers(){
    $levels = array('1'=>'Member','2'=>'Supporter','3'=>...);
    //do_query
    //loop results
    $ulevel = $levels[mysql_result($result,$i,"userlevel")];
    //continue loop
}
于 2013-07-23T08:42:08.633 回答