Cóż, to nie jest ładne, ale możesz to zrobić:
if @loopcntr = 1
set var01 = 'somevalue'
else if @loopcntr = 2
set var02 = 'whatever'
else if . . .
Powinno to być na tyle nieprzyjemne, że możesz pomyśleć o alternatywach. Och, oto dobry. Zdefiniuj zmienną tabeli i po prostu dodaj wiersze dla każdej wartości:
declare @vars table (
id int identity(1, 1),
loopcntr int,
value varchar(255)
);
. . .
-- inside the loop
insert into @vars(loopcntr, value)
select @loopcntr, 'whatever';
Jeśli chcesz uzyskać zmienną, możesz:
declare @var varchar(255);
select @var = value from @vars where loopcntr = <the one I want>;