首页 游戏 软件 资讯 排行榜 专题
首页
数据库
SQL怎样在查询中生成随机数序列_使用RAND或RANDOM函数

SQL怎样在查询中生成随机数序列_使用RAND或RANDOM函数

热心网友
41
转载
2026-04-26

SQL怎样在查询中生成随机数序列:使用RAND或RANDOM函数

SQL怎样在查询中生成随机数序列_使用RAND或RANDOM函数

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

MySQL里用RAND()生成每行不同的随机数

在MySQL里,想给每行数据配个随机数很简单,直接在SELECT列表里写上RAND()就行。它会为每一行返回一个0到1之间的浮点数。但这里有个关键细节容易被忽略:RAND()**不是常量表达式**。这意味着,即便在同一句查询里,你多次调用它,得到的结果也各不相同。不信?试试SELECT RAND(), RAND(),看看两列的值是不是几乎总不一样。

一个常见的“翻车”现场,是想用随机数打乱结果顺序,却忘了加ORDER BY。记住,SELECT * FROM t ORDER BY RAND()才是真正的随机排序;而SELECT *, RAND() FROM t仅仅是为结果集增加了一列随机值,行的先后顺序原封不动。

  • 如果需要整数随机数,可以用FLOOR(RAND() * N)得到0到N-1的范围,或者用CEIL(RAND() * N)得到1到N的范围。
  • 想复现相同的随机序列?这个需求在MySQL里有点难办。因为RAND()本身不支持种子参数。虽然有个RAND(N)的语法,但种子只在首次调用时生效,后续调用还是会“漂移”,无法保证稳定序列。
  • 最后,性能敏感的场景一定要慎用ORDER BY RAND()。这个操作会强制进行全表扫描并创建临时表排序,数据量一大,速度就会急剧下降。

PostgreSQL必须用RANDOM(),且不能在WHERE里依赖确定性

切换到PostgreSQL,函数名换成了RANDOM(),行为也更严格一些。它被标记为VOLATILE函数,优化器不会缓存或复用它的结果。也就是说,哪怕在同一行里多次出现,RANDOM()也会被重新计算。

这里有个典型陷阱:想随机抽取10%的数据样本,写WHERE RANDOM() < 0.1是可行的。但如果写成SELECT *, RANDOM() AS r FROM t WHERE r < 0.1,就会报错。原因在于,列别名rWHERE子句执行的阶段还不可见。

  • 正确的写法只有两种:要么直接在WHERE里用RANDOM() < 0.1,要么通过子查询:SELECT * FROM (SELECT *, RANDOM() AS r FROM t) s WHERE s.r < 0.1
  • 需要可重现的随机序列?可以配合SET seed使用。例如SELECT SETSEED(0.123); SELECT RANDOM();。需要注意的是,SETSEED是会话级别的,且只影响后续的RANDOM()调用。
  • RANDOM()可以用在GROUP BYORDER BY里,但这会导致分组或排序结果不稳定,除非你明确需要这种随机分组的效果。

SQL Server没有内置RAND()行级函数,得绕道NEWID()CHECKSUM()

SQL Server的情况比较特殊。它的RAND()是会话级单次求值函数——在整个查询中,所有行返回的都是同一个值,完全无法满足“每行一个随机数”的需求。真想用,必须借助其他机制。

最常用的组合拳是ABS(CHECKSUM(NEWID())) % N。思路是利用NEWID()每次生成唯一GUID的特性,通过CHECKSUM转换成整数,再取模得到0到N-1范围的整数。这个组合能保证行级独立性,而且不需要提前初始化种子。

  • 要避免直接让RAND()参与WHEREORDER BY,否则整个结果集只会按照同一个随机值来处理,失去随机意义。
  • 如果目标是随机抽样,TABLESAMPLE比手动计算随机数更高效(例如SELECT * FROM t TABLESAMPLE (10 PERCENT))。不过它基于数据页进行抽样,并非严格的行级均匀分布。
  • NEWID()方案虽然有一点性能开销(生成GUID+计算哈希),但远比误用RAND()导致的逻辑错误要好得多。

跨数据库生成固定范围随机整数的可移植写法

很遗憾,没有银弹。各个数据库对“随机”的语义和稳定性处理差异太大,强行编写统一的SQL极易出错。如果必须兼顾多个数据库,建议把随机数生成的逻辑上移到应用层处理,或者使用条件化的SQL模板。

举个例子,生成1到100的随机整数,在不同数据库中的写法差异就很明显:MySQLFLOOR(1 + RAND() * 100)PostgreSQLFLOOR(1 + RANDOM() * 100),而SQL Server则必须写成ABS(CHECKSUM(NEWID())) % 100 + 1

  • 别试图用COALESCE(RAND(), RANDOM(), ...)这种写法来兼容——语法上直接就会报错。
  • 测试时需要特别注意:同一句SQL在不同次执行中,结果是否符合预期的随机分布?比如ORDER BY RAND()是否真的随机了,还是因为索引或缓存的影响,看起来像是固定顺序。
  • 说到底,关键不在于记住函数名,而在于理解“该函数在当前上下文中是否被当作稳定表达式”。这一点直接决定了它能否被用于WHEREGROUP BY或窗口函数中。
来源:https://www.php.cn/faq/2312246.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

卡萨帝冰箱无法连接wi-fi怎么办?
电脑教程
卡萨帝冰箱无法连接wi-fi怎么办?

卡萨帝冰箱无法连接Wi-Fi?别急,这通常是几个可排查的技术环节在“作祟” 卡萨帝冰箱连不上家里的Wi-Fi,这事儿确实让人有点恼火。不过别担心,根据官方指南和大量的实测反馈,绝大多数问题都出在网络环境适配、密码输入规范或者设备协同设置这几个环节。好消息是,只要找准方向,超过九成的连接异常都能在十分

热心网友
04.26
怎样打开u盘需要密码?
电脑教程
怎样打开u盘需要密码?

怎样打开设置了密码的U盘? 给U盘设了密码,结果自己打不开了——这事儿听起来有点戏剧性,但在数据安全领域,这恰恰是加密机制正常工作的标志。简单来说,一把锁配一把钥匙,加密后的U盘必须通过当初设置它的那套“原装工具”和“唯一密码”才能访问。目前主流的方案就那么几种:Windows自带的BitLocke

热心网友
04.26
帅丰集成灶调火苗是调风门还是旋钮
电脑教程
帅丰集成灶调火苗是调风门还是旋钮

帅丰集成灶调节火苗主要依靠旋钮控制,部分型号已取消传统风门结构 说到调节火力,帅丰集成灶的核心在于那个手感清晰的旋钮。多数新型号已经取消了传统的风门结构,转而通过高精度的燃气阀体来实现无级调节。旋转旋钮,实际上就是在直接控制一个精密的燃气比例阀,旋转角度与燃气流量是精准对应的。官方技术资料显示,其调

热心网友
04.26
键盘设置在哪里找 Mac?
电脑教程
键盘设置在哪里找 Mac?

Mac键盘设置:从基础操作到高阶定制,一篇讲透 Mac的键盘设置,其实都集中在一个地方——“系统设置”应用里的“键盘”面板。这是从macOS Ventura开始的标准操作入口。你只需要从屏幕左上角的苹果菜单进入“系统设置”,然后在侧边栏里找到并点击“键盘”,就能管理所有相关选项了。无论是调整打字手感

热心网友
04.26
poe交换机不供电是交换机坏了吗
电脑教程
poe交换机不供电是交换机坏了吗

POE交换机不供电?别急着换设备,先按这四步查 遇到POE交换机不给摄像头或其他设备供电,先别断定是交换机坏了。从一线运维的反馈和主流厂商的技术支持案例来看,超过八成的供电故障,根源并不在交换机硬件本身,而是一些可以排查和解决的条件问题。 问题可能出在几个关键环节:比如使用的网线不达标,只通了四芯,

热心网友
04.26

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

以色列和黎巴嫩之间的跨境交火威胁着脆弱的停火协议
web3.0
以色列和黎巴嫩之间的跨境交火威胁着脆弱的停火协议

以色列和黎巴嫩之间的跨境交火仍在继续,破坏了近期达成的停火协议 目前,市场对特朗普在4月30日前支持以色列停火的反向合约预测概率,已经达到了100%。这个数字看起来很绝对,但现实往往比数据更复杂。 真主党近期的违约行为,以及以色列随之而来的回应,无疑将停火协议的脆弱性暴露无遗。市场虽然同样以100%

热心网友
04.27
Debian Apache如何防范安全攻击
网络安全
Debian Apache如何防范安全攻击

Debian 上加固 Apache 的安全实践 在Debian系统上运行Apache,安全加固不是一道选择题,而是一道必答题。一套系统性的加固策略,往往能在不惊动业务的前提下,将安全水平提升好几个等级。下面,我们就按从基础到进阶的顺序,一步步来。 一 基础加固 万丈高楼平地起,安全加固也得从最根本的

热心网友
04.27
CentOS Exploit漏洞是如何利用的
网络安全
CentOS Exploit漏洞是如何利用的

CentOS系统安全漏洞与攻击路径深度解析 在CentOS服务器安全防护中,理解攻击者的典型入侵路径至关重要。一次完整的攻击通常遵循“初始访问→本地提权→持久化 横向移动”的链条。本文将系统梳理CentOS环境下常见的漏洞利用方式、成功所需的关键条件以及对应的防御加固方案,帮助运维人员与安全工程师精

热心网友
04.27
CentOS Exploit漏洞修复有哪些步骤
网络安全
CentOS Exploit漏洞修复有哪些步骤

CentOS 漏洞修复与系统加固完整指南 当CentOS系统面临安全漏洞威胁时,建立一套系统性的应急响应与修复流程至关重要。这不仅是为了快速封堵安全缺口,更是为了最大限度保障业务连续性、降低数据泄露与系统停机的风险。本文提供从紧急处置到长效防护的完整操作路径,帮助您高效应对安全挑战。 一、紧急响应与

热心网友
04.27
4月27日加密货币市场整体更新:恐慌指数升至47,整体上涨1.7%。
web3.0
4月27日加密货币市场整体更新:恐慌指数升至47,整体上涨1.7%。

今日24小时加密货币市场新闻:Zerobase上涨31%,LUNC上涨19% 2026年4月27日,加密货币市场迎来了一个温和的上涨日。总市值增长了1 7%,攀升至2 71万亿美元,这主要得益于比特币和以太坊的领涨。虽然其他加密货币表现分化,但在成交量稳定和宏观环境向好的背景下,市场情绪已明显回暖,

热心网友
04.27