如何为玩家提供唯一编号


How to give unique numbers to players

我正在制作一个脚本,当玩家计数为 4 时,我将给出玩家编号。现在我有一个玩家表,我将用玩家号码更新它,但我似乎无法同时容纳唯一号码生成和更新表循环......在脚本的这种条件下,我会给所有玩家第 3 号......

到目前为止,我所拥有的是这样的:

<?PHP 
include '../config.php';
$con = mysql_connect($hostip, $mysqluser, $mysqlpass);
if (!$con) {
    die('Could not connect: ' . mysql_error());
}
mysql_select_db($mysqldatabase, $con);
$gameid = '08e893ac1c4446758ee44423c173c5aa';
/////////////////////////// mysq connect end
$sql=mysql_query("SELECT DISTINCT username FROM table");
$pn = array();
 while ( count($pn) < 4 ) {
    $random = mt_rand(1,4);       
    if ( !in_array($random,$pn) ) {
      $pn[] = $random;
      $rr = $random;
      while ($rowx = mysql_fetch_array($sql)) {
        echo $rr.'  '.$rowx['username'].' ';
      }
    }
 }
print_r($pn); ?>

输出为

3 user1 3 user2 3 user3 3 user4 Array ( [0] => 3 [1] => 1 [2] => 4 [3] => 2 )

我想它只得到第一个数字...我也尝试过其他方式,但这似乎是一个更好的方法来寻找解决方案。

编辑解决方案

$randoms = range(1, 4);
shuffle($randoms);


    while ($rowx = mysql_fetch_array($sql)){
         $random = array_shift($randoms);
    echo $random.'  '.$rowx['username'].' ';
    }

不要循环调用mt_rand,提前生成一个随机列表,并在需要时选择数字:

$randoms = range(1, 4);
shuffle($randoms);
while(...) {
  $random = array_shift($randoms);