खोज…


वाक्य - विन्यास

  • DECLARE कर्सर_नाम कूर्स [LOCAL | अंतर्राष्ट्रीय]
    • [FORWARD_ONLY | SCROLL]
      [STATIC | KEYSET | डायनामिक | तेजी से आगे बढ़ना ]
      [READ_ONLY | SCROLL_LOCKS | वैकल्पिक]
      [TYPE_WARNING]
    • Select_statement के लिए
    • [अद्यतन के लिए [कॉलम_नाम [, ... एन]]]

टिप्पणियों

आम तौर पर आप कर्सर का उपयोग करने से बचना चाहेंगे क्योंकि वे प्रदर्शन पर नकारात्मक प्रभाव डाल सकते हैं। हालांकि कुछ विशेष मामलों में आपको अपने डेटा रिकॉर्ड के माध्यम से लूप करने और कुछ कार्रवाई करने की आवश्यकता हो सकती है।

बेसिक फॉरवर्ड ओनली कर्सर

आम तौर पर आप कर्सर का उपयोग करने से बचना चाहेंगे क्योंकि वे प्रदर्शन पर नकारात्मक प्रभाव डाल सकते हैं। हालांकि कुछ विशेष मामलों में आपको अपने डेटा रिकॉर्ड के माध्यम से लूप करने और कुछ कार्रवाई करने की आवश्यकता हो सकती है।

DECLARE @orderId AS INT

-- here we are creating our cursor, as a local cursor and only allowing 
-- forward operations
DECLARE rowCursor CURSOR LOCAL FAST_FORWARD FOR
    -- this is the query that we want to loop through record by record
    SELECT [OrderId]
    FROM [dbo].[Orders]

-- first we need to open the cursor
OPEN rowCursor

-- now we will initialize the cursor by pulling the first row of data, in this example the [OrderId] column,
-- and storing the value into a variable called @orderId
FETCH NEXT FROM rowCursor INTO @orderId

-- start our loop and keep going until we have no more records to loop through
WHILE @@FETCH_STATUS = 0 
BEGIN

    PRINT @orderId
    
    -- this is important, as it tells SQL Server to get the next record and store the [OrderId] column value into the @orderId variable
    FETCH NEXT FROM rowCursor INTO @orderId

END

-- this will release any memory used by the cursor
CLOSE rowCursor
DEALLOCATE rowCursor

रुडिमेंटरी कर्सर सिंटैक्स

एक सरल कर्सर सिंटैक्स, कुछ उदाहरण परीक्षण पंक्तियों पर काम कर रहा है:

/* Prepare test data */
DECLARE @test_table TABLE
(
    Id INT,
    Val VARCHAR(100)
);
INSERT INTO @test_table(Id, Val)
VALUES 
    (1, 'Foo'), 
    (2, 'Bar'), 
    (3, 'Baz');
/* Test data prepared */

/* Iterator variable @myId, for example sake */
DECLARE @myId INT;

/* Cursor to iterate rows and assign values to variables */
DECLARE myCursor CURSOR FOR
    SELECT Id
    FROM @test_table;

/* Start iterating rows */
OPEN myCursor;
FETCH NEXT FROM myCursor INTO @myId;

/* @@FETCH_STATUS global variable will be 1 / true until there are no more rows to fetch */
WHILE @@FETCH_STATUS = 0
BEGIN

    /* Write operations to perform in a loop here. Simple SELECT used for example */
    SELECT Id, Val
    FROM @test_table 
    WHERE Id = @myId;

    /* Set variable(s) to the next value returned from iterator; this is needed otherwise the cursor will loop infinitely. */
    FETCH NEXT FROM myCursor INTO @myId;
END
/* After all is done, clean up */
CLOSE myCursor;
DEALLOCATE myCursor;

SSMS के परिणाम। ध्यान दें कि ये सभी अलग-अलग प्रश्न हैं, वे किसी भी तरह से एकीकृत नहीं हैं। ध्यान दें कि क्वेरी इंजन एक सेट के बजाय एक-एक करके प्रत्येक पुनरावृत्ति को कैसे संसाधित करता है।

ईद वैल
1 फू
(1 पंक्ति) प्रभावित
ईद वैल
2 बार
(1 पंक्ति) प्रभावित
ईद वैल
3 बाज
(1 पंक्ति) प्रभावित


Modified text is an extract of the original Stack Overflow Documentation
के तहत लाइसेंस प्राप्त है CC BY-SA 3.0
से संबद्ध नहीं है Stack Overflow