博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
SQLSever: 如何在select中的每一行产生不同的随机数?
阅读量:6236 次
发布时间:2019-06-22

本文共 1002 字,大约阅读时间需要 3 分钟。

原文:

select 的随机函数有点假, 也许是因为它是基于时间来的吧, 同一select中由于时间无法错开导致产生的随机数都是一样的, 如何做到让不同的行拥有不同的随机数呢?

下面以产生某个月的随机日期来示例吧。

--创建最小为1 最大为31 的视图if object_id('view_rand_int31') is not nullbegin	drop view view_rand_int31endgocreate view view_rand_int31as 	select cast(ceiling(rand() * 31) as int) as [r]go--创建日期(天)的随机函数if object_id('dbo.Fun_GetRandDay') is not nullbegin	drop function dbo.Fun_GetRandDayendgoCREATE FUNCTION dbo.Fun_GetRandDay(@max INT)returns intas begin	declare @r int	select @r = [r] from view_rand_int31		while @r>@max	begin		select @r = [r] from view_rand_int31		if @r<=@max		begin			break;		end	end	return @rendgo--试验select条件下实现多条记录同时取随机数--插入试验数据行declare @t table(rowNum int identity, [yearMonth] nvarchar(20))declare @i int,@imax intselect @i=1,@imax =28while @i<=@imaxbegin	insert into @t ([yearMonth]) select '2014年2月'	set @i=@i+1end--执行查询select *,  	cast( '2014-02-' + cast( dbo.Fun_GetRandDay(28) as varchar(2)) as datetime) as [date], 	(select cast(ceiling(rand() * 28) as int)) as [r]  from @t

转载地址:http://fgwia.baihongyu.com/

你可能感兴趣的文章
SQL Server 表的管理_关于事务的处理的详解(案例代码)
查看>>
转 struts2自定义404页面以及返回status code为404的方法
查看>>
Python2 JSON.load成Unicode的坑
查看>>
让Baidu和Google收录你的Hexo博客
查看>>
TypeScript 2019 路线图:更效率,更易用!
查看>>
【微信】第三方登录接口流程
查看>>
纯C实现的词法分析和lex实现的词法分析的对比
查看>>
喧喧发布 2.5.3 版本,主要提升系统稳定性,优化交互体验
查看>>
iOS应用显示一直安装,重启无效,也删除不了问题
查看>>
怎么把荣耀8x的手机备忘录导到电脑里?
查看>>
Elastic Search 新手入门笔记(一)
查看>>
把 Excel 透视表搬到 WEB 上
查看>>
Jenkins配合github实现前端项目自动化构建部署
查看>>
荐书:「时差党」——出国留学不是一件容易的事
查看>>
用户自定义结构数据与VARIANT转换
查看>>
java8-lambda
查看>>
Windows平台JxCore打包
查看>>
[译]ASP.NET Core依赖注入深入讨论
查看>>
设计模式(九)_代理模式
查看>>
02 回归算法 - 线性回归求解 θ(最大似然估计求解)
查看>>