SQL Server 从一组数字中随机获取一个数
很多人在开发需求中想获取一个随机数,或者从一组数字中获取一个数, 这个需求很简单,而且有很多方式可以实现,下面就介绍几种常见的方式,以作为笔记或供有需要的人参考.
比如有一组数字: 57 59 63 66 89 92 95,我们要从中随机取出一个:
方法一: 建表
--创建中间表存放随机数字 CREATE TABLE rand_number(id INT IDENTITY,num INT); INSERT INTO dbo.rand_number ( num )--57 59 63 66 89 92 95 VALUES ( 57 ),( 59 ),( 63 ),( 66 ),( 89 ),( 92 ),( 95 );
取随机数
SELECT num FROM dbo.rand_number WHERE id=ROUND(RAND()*6+1,0);
方法二: 不建表(CTE虚拟表)
;WITH temp_table AS( SELECT 1 id,57 num UNION ALL SELECT 2 id,59 num UNION ALL SELECT 3 id,63 num UNION ALL SELECT 4 id,66 num UNION ALL SELECT 5 id,89 num UNION ALL SELECT 6 id,92 num UNION ALL SELECT 7 id,95 num ) SELECT num FROM temp_table WHERE id=ROUND(RAND()*6+1,0);
方法三: 不建表 (派生表)
SELECT TOP 1 num FROM( SELECT 57 num UNION ALL SELECT 59 UNION ALL SELECT 63 UNION ALL SELECT 66 UNION ALL SELECT 89 UNION ALL SELECT 92 UNION ALL SELECT 95 )t ORDER BY NEWID();
分类:
T-SQL
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律