php – 如何为laravel中的每个用户生成唯一的随机值并将其添加到数据库

前端之家收集整理的这篇文章主要介绍了php – 如何为laravel中的每个用户生成唯一的随机值并将其添加到数据库前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我正在开发一个活动组织网站.在这里,当用户注册一个事件时,他将获得一个唯一的随机数(10位数),我们用它来生成条形码并将其邮寄给他.现在,

>我想为每个注册的活动提供唯一的号码.
>也随机

一种解决方案是获取数组中的所有随机数并使用PHP rand(1000000000,9999999999)生成随机数并循环并检查所有值.获取不等于数组中任何值的第一个值,并将其添加数据库中.

但我认为可能有更好的解决方案.有什么建议吗?

最佳答案
你的逻辑在技术上并不是错误的.但是,如果您的应用程序吸引了大量用户,那么就资源和计算时间而言,获取所有随机数可能会变得不必要地昂贵.

我建议另一种方法,你生成一个随机数,然后对数据库进行检查.

function generateBarcodeNumber() {
    $number = mt_rand(1000000000,9999999999); // better than rand()

    // call the same function if the barcode exists already
    if (barcodeNumberExists($number)) {
        return generateBarcodeNumber();
    }

    // otherwise,it's valid and can be used
    return $number;
}

function barcodeNumberExists($number) {
    // query the database and return a boolean
    // for instance,it might look like this in Laravel
    return User::whereBarcodeNumber($number)->exists();
}

猜你在找的MySQL相关文章