Je ne suis pas sûr de DO-WHILE IN MS SQL Server 2008, mais vous pouvez modifier votre logique de boucle WHILE, de manière à UTILISER comme la boucle DO-WHILE.
Des exemples sont tirés d'ici :http://blog.sqlauthority.com/2007/10/24/sql-server-simple-example-of-while-loop-with-continue-and-break-keywords/
Exemple de boucle WHILE
DECLARE @intFlag INT SET @intFlag = 1 WHILE (@intFlag <=5) BEGIN PRINT @intFlag SET @intFlag = @intFlag + 1 END GO
Ensemble de résultats :
1 2 3 4 5
Exemple de boucle WHILE avec le mot-clé BREAK
DECLARE @intFlag INT SET @intFlag = 1 WHILE (@intFlag <=5) BEGIN PRINT @intFlag SET @intFlag = @intFlag + 1 IF @intFlag = 4 BREAK; END GO
Ensemble de résultats :
1 2 3
Exemple de boucle WHILE avec les mots clés CONTINUE et 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
Ensemble de résultats :
1 2 3 4 5
Mais essayez d'éviter les boucles au niveau de la base de données.Référence.