如何在倒计时完成后从MySql中选择随机行?

时间:2016-09-27 16:25:33

标签: php mysql database countdown

我这里有一个倒计时脚本

  <h2 id="countdown"></h2> 
<script>
  var CountDownTimer;

    CountDownTimer = function(dt, id) {
    var _day, _hour, _minute, _second, end, selector, showRemaining, timer;
    selector = document.getElementById(id);
    end = new Date(dt);
    _second = 1000;
    _minute = _second * 60;
    _hour = _minute * 60;
    _day = _hour * 24;
    showRemaining = function() {
        var days, distance, hours, minutes, now, seconds;
        now = new Date();
        distance = end - now;
        if (distance <= 0) {
            CountDownTimer("09/27/2016 20:00", "countdown");
            return;
        }
        days = Math.floor(distance / _day);
        hours = Math.floor((distance % _day) / _hour);
        minutes = Math.floor((distance % _hour) / _minute);
        seconds = Math.floor((distance % _minute) / _second);
        return selector.innerHTML = days + "days " + hours + "hrs " + minutes + "mins " + seconds + "secs";
    };
    return timer = setInterval(showRemaining, 1000);
    };

    CountDownTimer("09/27/2016 19:00", "countdown");
</script>

倒计时结束后,我希望查询从数据库中选择一个随机行,并重新开始倒计时到+1小时。 1小时后我想再次发生这种情况。

这是应该选择随机行的代码,如果可能的话,这是我想在倒计时脚本中得到的代码。

<?php $sql = "SELECT * FROM users ORDER BY RAND() LIMIT 1"; $result1 = $conn->query($sql);?>

以下是最后一个代码

的结果代码
<?php
if ($result1->num_rows > 0) {
    // output data of each row
    while($row = $result1->fetch_assoc()) {
        echo $row["username"];
    }
} ?>

此代码现在可以使用,但问题是每次刷新页面时,都会选择一个新的随机行。我想要的是每小时都会选择一个新的随机行。

2 个答案:

答案 0 :(得分:0)

当您生成随机数时,使用两个变量存储在会话中,一个用于存储数字,另一个用于存档时间。

每当用户访问您的页面时,在后端将检查是否在会话变量中设置了值,如果没有,则将保存新值,否则它将获取数字和检查时间。如果时间到期,则应生成新值。

答案 1 :(得分:0)

只需将所选用户的ID存储在一些附加表中。

例如在user_of_hour(hour,user_id)。

并检查:

  • 如果一个小时的用户已经存储,那么只需通过id
  • 获取
  • 如果没有则继续进行随机选择

小建议:

不要使用ORDER BY RAND() - 大数据集上的速度非常慢。