SqlServer 2008 創(chuàng)建測試數(shù)據(jù)的方法
發(fā)表時間:2023-07-18 來源:明輝站整理相關(guān)軟件相關(guān)文章人氣:
[摘要]包含要點: 數(shù)據(jù)庫的循環(huán) 、 insert select 句式 、 隨機(jī)數(shù)(rand()函數(shù))、絕對值(abs()函數(shù))DECLARE @starttime varchar(50)DECLARE...
包含要點: 數(shù)據(jù)庫的循環(huán) 、 insert select 句式 、 隨機(jī)數(shù)(
rand()函數(shù))、絕對值(
abs()函數(shù))
DECLARE @starttime varchar(50)
DECLARE @endtime varchar(50)
DECLARE @randomvalue float
SET @starttime='2017-09-15 00:15:00.000'
SET @endtime='2017-10-20 00:00:00.000'
-- set @randomvalue=floor(rand()*10)
-- -- select CONVERT(varchar(50), DATEADD(mi,15,@starttime),121)
--select [TagID],[Value]-@randomvalue,[StartValue]-@randomvalue,CONVERT(varchar(50),DATEADD(mi,15,[StartTime]),121),[EndValue]-@randomvalue,CONVERT(varchar(50),DATEADD(mi,15,[EndTime]),121)
--from [dbo].[DimTagMinuteData] where TagID in (1,
-- 2,3,4,5,6,
-- 7,8,9,10,11,
-- 12,13,14,15,16,
-- 17,18,19,20
-- )
--and StartTime=@starttime and EndTime=CONVERT(varchar(50),DATEADD(mi,15,@starttime),121)
WHILE @starttime<=@endtime
begin
set @randomvalue=floor(rand()*10)
IF @starttime<=@endtime
BEGIN
insert INTO DimTagMinuteData ([TagID],[Value],[StartValue]
,[StartTime]
,[EndValue]
,[EndTime])
select [TagID] ,
ABS([Value]-@randomvalue) ,
ABS([StartValue]-@randomvalue),
CONVERT(varchar(50),DATEADD(mi,15,[StartTime]),121),
ABS([EndValue]-@randomvalue),
CONVERT(varchar(50),DATEADD(mi,15,[EndTime]),121)
from [dbo].[DimTagMinuteData] where TagID in (1,
2,3,4,5,6,
7,8,9,10,11,
12,13,14,15,16,
17,18,19,20
)
and StartTime=@starttime and EndTime=CONVERT(varchar(50),DATEADD(mi,15,@starttime),121)
end
else
begin
print 'stop'
end
set @starttime= CONVERT(varchar(50), DATEADD(mi,15,@starttime),121)
end
-- 隨機(jī)數(shù)
select floor(rand()*100)當(dāng)然 循環(huán)的時候 可以不用 if else 判斷
以上就是SqlServer 2008 創(chuàng)建測試數(shù)據(jù)的方法的詳細(xì)內(nèi)容,更多請關(guān)注php中文網(wǎng)其它相關(guān)文章!
學(xué)習(xí)教程快速掌握從入門到精通的SQL知識。