1
以下是样本数据,需要帮助优化T-SQL查询
DECLARE @maxval int, @minval int
select @maxval=201301,@minval=201312
SELECT top 100001 CAST(((@maxval + 1) - @minval) *
RAND(CHECKSUM(NEWID())) + @minval AS int)Date ,ceiling (RAND(CHECKSUM(NEWID())) *1000+25692*RAND(CHECKSUM(NEWID())) )*ceiling (RAND(CHECKSUM(NEWID())) *1000+25692*RAND(CHECKSUM(NEWID())) )ID
into #sample from sysobjects , syscolumns
问题:
- 有2列迄今& ID
- 拿第一个月的ID,例如说201302
- 需要在接下来的3个月中查找这些ID是否可用。所以这里201303,201304,201305
- 需要重复此为所有几个月
这里是我的代码,它需要更多的人工干预和时间服用。请协助。
select distinct date from #sample order by DATE
declare @processingdate varchar(6),@from varchar(6),@to varchar(6)
set @processingdate = '201302'
set @from = '201303'
set @to = '201305'
select distinct id into #Source from #sample where DATE = @processingdate
select distinct id into #lookup from #sample where DATE between @from and @to
select @processingdate,count(*) from #Source where ID not in (select * from #lookup)
感谢
你可以添加一些示例数据,以证明你想要的结果? – MatBailie
有没有可以利用的优势? – gh9