Ich bin mir bei DO-WHILE IN MS SQL Server 2008 nicht sicher, aber Sie können Ihre WHILE-Schleifenlogik ändern, um sie wie eine DO-WHILE-Schleife zu VERWENDEN.
Beispiele sind hier entnommen:http://blog.sqlauthority.com/2007/10/24/sql-server-simple-example-of-while-loop-with-continue-and-break-keywords/
-
Beispiel einer WHILE-Schleife
DECLARE @intFlag INT SET @intFlag = 1 WHILE (@intFlag <=5) BEGIN PRINT @intFlag SET @intFlag = @intFlag + 1 END GO
Ergebnismenge:
1 2 3 4 5
-
Beispiel einer WHILE-Schleife mit BREAK-Schlüsselwort
DECLARE @intFlag INT SET @intFlag = 1 WHILE (@intFlag <=5) BEGIN PRINT @intFlag SET @intFlag = @intFlag + 1 IF @intFlag = 4 BREAK; END GO
Ergebnismenge:
1 2 3
-
Beispiel einer WHILE-Schleife mit den Schlüsselwörtern CONTINUE und 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
Ergebnismenge:
1 2 3 4 5
Aber versuchen Sie, Schleifen zu vermeiden auf Datenbankebene.Referenz.