`
mlzboy
  • 浏览: 726662 次
  • 性别: Icon_minigender_1
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

mysql rand(x)生产重复随机序列

阅读更多

MySQL随机函数的两种用法[rand()]

比如有一个需求,通过sql语句,返回-5至5的随机整数.如果这一个放在PHP中,则非常简单直接用 
<?php
print rand(-5,5);
?>
mysql中,rand函数只能有一个参数.
//摘自手册
RAND() RAND(N
返回一个随机浮点值 v ,范围在 0 到1 之间 (即, 其范围为 0 ≤ v ≤ 1.0)。若已指定一个整数参数 N ,则它被用作种子值,用来产生重复序列。

有两个方法可以达成以上效果.
1.新建一个表,里面存着 -5 至 5 之间的数.再利用order by rand()得到随机数.
#建立指定范围数据
#auther: 小强(占卜师) 
#date: 2008-03-31

create table randnumber
select -1 as number
union 
select -2
union 
select -3
union 
select -4
union 
select -5
union 
select 0
union 
select 1
union 
select 2
union 
select 3
union 
select 4
union 
select 5 

#得到随机数
#auther: 小强(占卜师) 
#date: 2008-03-31

select number
from randnumber order by rand() limit 1

优点: 随机数可以指定某部分数据,并不需要连续的.
缺点: 当随机数范围很广的时候,建表比较困难.
2.利用MySQL的ROUND()加上RAND()函数实现
#一句sql语句搞定
#auther: 小强(占卜师) 
#date: 2008-03-31

SELECT ROUND((0.5-RAND())*2*5) 
#注释
#0.5-rand()可以得到-0.5 至 +0.5的随机数
#(0.5-rand())*2可以得到-1 至 +1的随机数
#(0.5-rand())*2*5可以得到-5 至 +5的随机数
#ROUND((0.5-RAND())*2*5)可以得到-5 至 +5的随机整数



优点: 当随机数范围很广的时候,只需要更改*5当中的5即可,非常方便.
缺点: 随机数只能是连续的,不可以指定某部分数据.
原创文章,欢迎转载。转载请注明来自[phpchina.com]即可。两

[ 本帖最后由 coolstr 于 2008-3-31 13:52 编辑 ]
分享到:
评论

相关推荐

    MySQL中的RAND()函数使用详解

    MySQL中的RAND()函数是一个非常有用的内置函数,它用于生成0到1之间的随机浮点数。在SQL查询中,RAND()可以被用在多种场景下,例如创建随机数据、进行随机抽样或者对结果集进行随机排序。 首先,当我们直接调用RAND...

    mysql生成指定位数的随机数及批量生成随机数的方法

    尽管在单个记录中使用 `RAND()` 可能不会立即引起问题,但如果你需要大量不重复的随机数,可能需要采用不同的策略,如先生成一个不重复的数字序列,然后再进行分配。 在实际应用中,生成随机数可以用于创建测试数据...

    mysql常用函数

    12. **RAND()**: 返回0到1之间的随机值,可以接受一个种子作为参数来固定随机序列。 - 例如:`RAND(1)` 可能返回 `0.834567`。 13. **ROUND(x,y)**: 返回参数`x`四舍五入后的小数位数为`y`的值。 - 例如:`ROUND...

    mysql2005常用函数

    - `RAND([integer_expression])`:生成0到1之间的随机浮点数,可选的种子值用于确定随机序列。 6. **字符串函数**: - `ASCII()`:返回字符的ASCII码。 - `CHAR()`:根据ASCII码返回对应的字符。 - `LOWER()`:...

    MySQL性能优化

    如果确实需要随机结果,可以考虑其他方法,比如先生成一个随机数列,再基于该序列进行排序。 #### 7. 避免使用`SELECT *` - **明确指定所需字段**:当执行查询时,应当明确指定所需的字段而不是使用`SELECT *`。...

    PHP与MySQL程序设计

    - **返回一组随机的键**:使用`array_rand()`。 - **随机洗牌数组元素**:使用`shuffle()`。 以上概述了《PHP与MySQL程序设计》一书的部分内容,旨在帮助读者理解PHP的基本概念和技术要点。接下来的章节将继续...

    MySQL数学函数简明总结

    这在需要重复测试或创建可预测的随机序列时非常有用。 了解并熟练运用这些MySQL数学函数,能帮助数据库管理员和开发者更高效地处理数值计算,进行复杂的统计分析,或者构建动态的数据生成过程。在实际工作中,这些...

    035-关于floor()报错注入,你真的懂了吗?.pdf

    如果为rand()指定了一个整数参数N,那么这个参数就会作为种子值来使用,rand()函数将根据这个种子值来生成一个重复的随机数序列。这样,只要种子值不变,每次调用rand()函数的结果将是可预测的。 文章提到了使用...

    sqlserver 不重复的随机数

    本篇文章主要探讨如何利用SQL Server的内置函数来创建一个不重复的随机字符串序列。 首先,我们要理解如何在SQL Server中生成随机字符。这里使用了`CHAR()`函数,它能将一个ASCII码转换为对应的字符。ASCII码是从0...

    PHP生成唯一会员卡号

    通常,会员卡号需要具有一定的结构,以便于美观和易于记忆,同时还要包含一些随机或序列化的元素以确保唯一性。以下是一些实现这个功能的关键知识点: ### 1. 唯一性保证 在设计会员卡号系统时,首要任务是确保生成...

    开奖器 php万能代码

    对于更复杂的随机序列,可以使用`random_bytes()`或`openssl_random_pseudo_bytes()`。 2. **数据库交互**:开奖结果往往需要存储在数据库中,PHP可以使用PDO(PHP Data Objects)或者MySQLi扩展来连接和操作MySQL...

    PHP舒尔特25方格游戏.zip

    每个数字的范围通常是1到25,确保没有重复,可以使用`array_unique()`函数去除重复项。然后,通过调整数组元素的位置达到随机排列的效果。 ```php $numbers = range(1, 25); shuffle($numbers); $grid = array_...

    VC 生成随机数曲线.rar

    在VC++中,可以使用`&lt;cstdlib&gt;`库中的`rand()`函数生成[0, RAND_MAX]范围内的均匀分布随机数,通过适当调整范围可满足特定需求。 - **正态分布(Normal Distribution)**:也称为高斯分布,具有钟形曲线特征,其...

    PHP wordpress 扑克牌验证码

    2. **随机化扑克牌**:通过PHP的随机数生成函数(如`random_int()`或`mt_rand()`)来决定显示的扑克牌。 3. **设置验证规则**:定义用户需要遵循的验证规则,如按顺序输入或按花色分类。 4. **用户交互**:用户在...

    基于PHP的APP抽奖砸金蛋php版源码.zip

    【压缩包子文件的文件名称列表】"132692268818556747" 这个文件名看起来像是一个随机生成的数字序列,可能代表了源码包的一个特定版本或时间戳。由于没有具体的文件扩展名,这可能是一个数据文件,如数据库备份、...

    PHP 验证码的实现代码

    它通过创建一个用户必须输入的随机字符序列来验证用户是人类而非计算机程序。以下是对PHP验证码实现的详细解释: 首先,我们来看`checkcode.php`文件,这是生成验证码图片的脚本。在这个脚本中: 1. `session_...

    java,C#,PHP等实现手机发送验证码Demo

    首先,我们要了解验证码的核心原理:生成一个随机的数字或字母序列,并通过某种方式(如短信或语音)发送到用户的手机上。用户收到验证码后,在应用程序内输入,系统再对输入的验证码进行验证。这个过程涉及到以下几...

    JSP教程文档_从入门到精通_一步一步学习

    使用ObjectInputStream和ObjectOutputStream序列化和反序列化对象。 **4.7 RandomAccessFile类** RandomAccessFile类支持随机访问文件: ```java RandomAccessFile raf = new RandomAccessFile("example.txt", "rw...

Global site tag (gtag.js) - Google Analytics