Solved

how can i use for loop in stored procedure in sql server ??

Posted on 2011-03-03
13
772 Views
Last Modified: 2012-05-11
i want to know that how can i use for loop in stored procedure in MS SQL Server ??

please refer the below strored procedure ...

CREATE PROCEDURE usp_SaveNewQuestion
    (
      @uid INT ,
      @Question VARCHAR(200) ,
      @correctOpt VARCHAR(50)
    )
AS 
    BEGIN

        INSERT  INTO Details
                SELECT  uname ,
                        pwd ,
                        email ,
                        login_time ,
                        @Question ,
                        @correctOpt ,
                        logout_time ,
                        comment
                FROM    Details
                WHERE   uid = @uid
        

    END
GO

Open in new window


how can i use for loop in above stored procedure ??
0
Comment
Question by:Parth48
  • 4
  • 4
  • 3
  • +2
13 Comments
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 35033870
sql u have to use cursor

here is the simple cursor implementation
syntax:
DECLARE cursor_name [INSENSITIVE] [SCROLL] CURSOR
FOR select_statement
[FOR {READ ONLY | UPDATE [OF column_name [,...n]]}]

Open in new window


here is the complate example
http://www.mssqlcity.com/Articles/General/UseCursor.htm
0
 
LVL 10

Expert Comment

by:Jini Jose
ID: 35033873
can u please tell what for you using the loop in your stored procedure ?
for inserting the data ?
0
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 35033876
you can use while loop like this

DECLARE @intFlag INT
SET @intFlag = 1
WHILE (@intFlag <=5)
BEGIN
PRINT @intFlag
SET @intFlag = @intFlag + 1
END
0
PRTG Network Monitor: Intuitive Network Monitoring

Network Monitoring is essential to ensure that computer systems and network devices are running. Use PRTG to monitor LANs, servers, websites, applications and devices, bandwidth, virtual environments, remote systems, IoT, and many more. PRTG is easy to set up & use.

 

Author Comment

by:Parth48
ID: 35034003
hello @pratima_mcs: Thanks , in both the way u r right , but which is the better way according to u , using cursor or while loop ??
0
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 35034023
it really depends on your situation. I almost always use a cursor to loop through records when necessary. The cursor format is a little more intuitive for me and, since I just use the constructs to loop through the result set once, it makes sense to use the FAST_FORWARD cursor. Remember that the type of cursor you use will have a huge impact on the performance of your looping construct.

for more details refer

http://www.techrepublic.com/blog/datacenter/comparing-cursor-vs-while-loop-performance-in-sql-server-2008/1741
0
 

Expert Comment

by:h_aravind
ID: 35034030
You can use a While loop rather than using a cursor. cursors are performance hit.
0
 
LVL 1

Accepted Solution

by:
lalitgada earned 500 total points
ID: 35034081
USE AdventureWorks;
GO
DECLARE @Flag INT
SET @Flag = 1
WHILE (@Flag < 10)
BEGIN
BEGIN
PRINT @Flag
SET @Flag = @Flag + 1
END
IF(@Flag > 5)
BREAK
ELSE
CONTINUE
END
WHILE loop can use SELECT queries as well. You can find following example of BOL very useful.
USE AdventureWorks;
GO
WHILE (
SELECT AVG(ListPrice)
FROM Production.Product) < $300
BEGIN
UPDATE Production.Product
SET ListPrice = ListPrice * 2
SELECT MAX(ListPrice)
FROM Production.Product
IF (
SELECT MAX(ListPrice)
FROM Production.Product) > $500
BREAK
ELSE
CONTINUE
END
PRINT 'Too much for the market to bear';
0
 

Author Comment

by:Parth48
ID: 35034152
hi @lalitgada: where i can download AdventureWorks database ??

is it on MSDN ??
0
 
LVL 39

Expert Comment

by:Pratima Pharande
ID: 35034157
AdventureWorks is default database on SQl server
0
 

Expert Comment

by:h_aravind
ID: 35034171
Adventure works, northwind database etc can be downloaded from Microsoft website or from codeplex.com
0
 

Author Comment

by:Parth48
ID: 35034172
hi @h_aravind: can u please post the download link ??
0
 

Expert Comment

by:h_aravind
ID: 35034179
Can you try this?

http://sqlserversamples.codeplex.com/

This has details for both 2005 & 2008
0
 

Author Comment

by:Parth48
ID: 35034369
hi @h_aravind: thanks for the link ....
0

Featured Post

Windows Server 2016: All you need to know

Learn about Hyper-V features that increase functionality and usability of Microsoft Windows Server 2016. Also, throughout this eBook, you’ll find some basic PowerShell examples that will help you leverage the scripts in your environments!

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Title # Comments Views Activity
Web site error 3 36
PrintingFoundIt(Almost!(Damn!)) 1 26
HTML - Color not displaying correctly in EMAIL. 6 32
replicated - directional or bidirectional? 3 29
International Data Corporation (IDC) prognosticates that before the current the year gets over disbursing on IT framework products to be sent in cloud environs will be $37.1B.
The article shows the basic steps of integrating an HTML theme template into an ASP.NET MVC project
This Micro Tutorial will teach you how to censor certain areas of your screen. The example in this video will show a little boy's face being blurred. This will be demonstrated using Adobe Premiere Pro CS6.
This is used to tweak the memory usage for your computer, it is used for servers more so than workstations but just be careful editing registry settings as it may cause irreversible results. I hold no responsibility for anything you do to the regist…

813 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question

Need Help in Real-Time?

Connect with top rated Experts

18 Experts available now in Live!

Get 1:1 Help Now