Cursors in SQL: Definition, Types and Lifecycle

Cursors in SQL: Definition, Types and Lifecycle

4 mins read2.1K Views Comment
Updated on Apr 29, 2022 13:12 IST

In this article, we will talk about the definition, types and lifecycle of cursors in SQL. Do take a look to learn about SQL cursors in detail.

2022_04_Add-a-heading-9.jpg

With large amounts of data stored in databases, it is of utmost importance for the users to travel through the databases. Cursors as the name suggest pinpointing the data to where you wish to allow traversal and allow the traversal of data. In this article on Cursors in SQL, we will discuss the following topics:

What is a Cursor in SQL?

As mentioned above, Cursors are objects that allow the traversal of data over the rows. You can consider cursors as a pointer pointing to the present row from an arrangement of rows. 

It is a temporary space in the memory system during the execution of a SQL statement. It stores the retrieved data from the database and can process only a single row at a time. 

Also, all the rows held by a cursor are considered an active set.  

Syntax:

[code]
CURSOR CursorName IS SELECT Statement;
[/code]

Example:

[code]
CURSOR CursorPat IS SELECT PatientName;
[/code]

There are various types of cursors that perform different data operations. Next in this article let us understand the types of cursors in SQL.

Recommended online courses

Best-suited Database and SQL courses for you

Learn Database and SQL with these high-rated online courses

– / –
2 months
4.24 K
6 weeks
– / –
15 hours
– / –
– / –
– / –
1 hours
– / –
30 hours
– / –
31 hours
– / –
80 hours

Types of Cursors in SQL

There are two types of cursors in SQL:

  • Implicit Cursor 
  • Explicit Cursor

Let us understand each one of them one by one:

Implicit Cursor

Implicit Cursors are used and generated automatically when the INSERT, DELETE and UPDATE operations are performed.

This type of cursor is used only for internal processing and cannot be referred to or controlled outside the space that the users are working on. So basically, the implicit cursors can be used to refer to the most recent cursor. Also, these types of cursors only store/hold the rows affected by the data operation. 

The following are a few cursor attributes used to refer to the most recent cursor:

  • %ROWCOUNT – Returns the count of rows affected by the INSERT, DELETE and UPDATE statements.
  • %ISOPEN – Returns FALSE for the implicit cursors, as the cursor is closed post the execution of the SQL statement.
  • %FOUND – Returns TRUE if the INSERT, DELETE, and UPDATE statement affect one or more rows.
  • %NOTFOUND – Returns TRUE if the INSERT, DELETE, and UPDATE statements do not affect one or more rows.

Check out more articles on SQL

Explicit Cursor

Explicit cursors are used whenever users process data through SQL blocks. This type of cursor holds more than one row, but can only process a single row at a time. 

So users can create a context area or a defined SQL block for the data manipulation operations. One such example is that of SQL triggers. 

Moving ahead in this article let us understand the lifecycle of Cursors in SQL.

Filtering Data with SQL
How to Create, Update, Insert and Delete SQL Views?
Understanding Subqueries in SQL

Lifecycle of an SQL Cursor

The lifecycle of the cursor has 6 stages:

  • Declaring a cursor
  • Opening a cursor
  • Fetching a cursor
  • Checking status
  • Closing a cursor
  • Deallocating a cursor

Declaring a cursor

Here, you have to specify the name and data type of the cursor.  You also have to mention the select statement in this step.

[code]
DECLARE CursorName CURSOR FOR SelectStatement;
[/code]

Opening a cursor

This stage of the lifecycle will let you open the cursor.

[code]
OPEN CursorName;
[/code]

Fetching a cursor

This step retrieves rows from the cursor and saves it in variables.

[code]
FETCH NEXT FROM CursorName INTO Variable;
[/code]

Checking Status

This stage of the lifecycle returns the status of the last FETCH statement executed against the cursor. In case you wish to fetch all rows from the cursor, then you must use the WHILE statement. If 0 is returned, then it indicates that the operation was successful.

[code]
WHILE @@FETCHSTATUS = 0
BEGIN
FETCH NEXT FROM CursorName;
END;
[/code] 

Closing a cursor

As the name suggests, this step will close the cursor.

[code]
CLOSE CursorName;
[/code]

Deallocating  a cursor

The final step will deallocate the cursor and free up the occupied memory space.

[code]
DEALLOCATE CursorName;
[/code]
 

With this, we end this article on Cursors in SQL. We hope you found it informative. You can refer to the article on MySQL Commands for a detailed walkthrough of all commands.

Top Trending Tech Articles:
Career Opportunities after BTech | Online Python Compiler | What is Coding | Queue Data Structure | Top Programming Language | Trending DevOps Tools | Highest Paid IT Jobs | Most In Demand IT Skills | Networking Interview Questions Features of Java | Basic Linux Commands | Amazon Interview Questions

Recently completed any professional course/certification from the market? Tell us what you liked or disliked in the course for more curated content.

Click here to submit its review with Shiksha Online.

About the Author

This is a collection of insightful articles from domain experts in the fields of Cloud Computing, DevOps, AWS, Data Science, Machine Learning, AI, and Natural Language Processing. The range of topics caters to upski... Read Full Bio