Я запрашиваю общий размер последних данных в определенных базах данных.
Я создаю таблицу, содержащую запрашиваемые БД, затем выполняю итерацию по ней, чтобы получить имена БД и общее количество раз для запускаитерация.
Затем я создаю шаблон, в который будут вставлены необходимые данные.
Я запускаю итерацию, чтобы получить информацию и вставить ее в шаблон для каждой базы данных.
После завершения итерации я не могу получить значения из этой вновь созданной таблицы.
Я написал небольшой комментарий рядом с каждой частью кода, объясняющий, что я пытаюсь сделать и чего я ожидаю.
/*check if the #databases table is already present and then drop it*/
IF OBJECT_ID('tempdb..#databases', 'U') IS NOT NULL
begin
drop table #databases;
end
select ArtifactID into #databases from edds.eddsdbo.[Case]
where name like '%Review%'
/*Once this first statement has been run there will now be a
number column that is associated with the artificatID. Each database has an area that is
titled [EDDS'artifactID']. So if the artifactID = 1111111 then the DB would
be accessed at [EDDS1111111]*/
declare @runs int = 1; /*this will track the number of times iterated
over the result set*/
declare @max int = 0; /*this will be the limit*/
declare @databasename sysname='' /*this will allow the population of each
database name*/
/*check if your temp table exists and drop if necessary*/
IF OBJECT_ID('tempdb..#temptable', 'U') IS NOT NULL
begin
drop table #temptable;
end
/*create the temp table as outside the loop*/
create table #temptable(
fileSize dec,
extractedTextSize dec
)
while @runs<=@max
begin
select @max=count(*) from #databases;
/*the @max is now the number of databases inserted in to this table*/
/*This select statement pulls the information that will be placed
into the temptable. This second statment should be inside the loop. One time
for each DB that appeared in the first query's results.*/
/*begin the loop by assigning your database name, I don't know what the
column is called so I have just called it databasename for now*/
select top 1 @databasename = ArtifactID from #databases;
/*generate your sql using the @databasename variable, if you want to make
the database and table names dynamic too then you can use the same formula*/
insert into #temptable
select SUM(fileSize)/1024/1024/1024, SUM(extractedTextSize)/1024/1024
FROM [EDDS'+cast(@databasename as nvarchar(128))+'].[EDDSDBO].[Document] ed
where ed.CreatedDate >= (select CONVERT(varchar,dateadd(d,-
(day(getdate())),getdate()),106))'
/*remove that row from the databases table so the row won't be redone
This will take the @max and lessen it by one*/
delete from #databases where ArtifactID=@databasename;
/* Once the @max is less than 1 then end the loop*/
end
/* Query the final values in the temp table after the iteration is complete*/
select filesize+extractedTextSize as Gigs from #temptable
Когда этот последний оператор select выполняется для извлечения значений из #temptable, ответ представляет собой один столбец Gigs (как и ожидалось), но сама таблица пуста.
Что-то происходит, чтобы удалить данные из таблицы, и я застрял.
Я не уверен, что моя ошибка в синтаксисе или общая ошибка логики, но любая помощь могла быс благодарностью.