Não tenho certeza sobre DO-WHILE no MS SQL Server 2008, mas você pode alterar sua lógica de loop WHILE, para usar como loop DO-WHILE.
Exemplos são retirados daqui:http://blog.sqlauthority.com/2007/10/24/sql-server-simple-example-of-while-loop-with-continue-and-break-keywords/
Exemplo de loop WHILE
DECLARE @intFlag INT SET @intFlag = 1 WHILE (@intFlag <=5) BEGIN PRINT @intFlag SET @intFlag = @intFlag + 1 END GO
Conjunto de resultados:
1 2 3 4 5
Exemplo de loop WHILE com palavra-chave BREAK
DECLARE @intFlag INT SET @intFlag = 1 WHILE (@intFlag <=5) BEGIN PRINT @intFlag SET @intFlag = @intFlag + 1 IF @intFlag = 4 BREAK; END GO
Conjunto de resultados:
1 2 3
Exemplo de loop WHILE com palavras-chave CONTINUE e BREAK
DECLARE @intFlag INT SET @intFlag = 1 WHILE (@intFlag <=5) BEGIN PRINT @intFlag SET @intFlag = @intFlag + 1 CONTINUE; IF @intFlag = 4 -- This will never executed BREAK; END GO
Conjunto de resultados:
1 2 3 4 5
Mas tente evitar loops no nível do banco de dados. Referência.