Sign Up

Sign Up to our social questions and Answers Engine to ask questions, answer people’s questions, and connect with other people.

Have an account? Sign In

Have an account? Sign In Now

Sign In

Login to our social questions & Answers Engine to ask questions answer people’s questions & connect with other people.

Sign Up Here

Forgot Password?

Don't have account, Sign Up Here

Forgot Password

Lost your password? Please enter your email address. You will receive a link and will create a new password via email.

Have an account? Sign In Now

You must login to ask a question.

Forgot Password?

Need An Account, Sign Up Here

Please briefly explain why you feel this question should be reported.

Please briefly explain why you feel this answer should be reported.

Please briefly explain why you feel this user should be reported.

Sign InSign Up

The Archive Base

The Archive Base Logo The Archive Base Logo

The Archive Base Navigation

  • SEARCH
  • Home
  • About Us
  • Blog
  • Contact Us
Search
Ask A Question

Mobile menu

Close
Ask a Question
  • Home
  • Add group
  • Groups page
  • Feed
  • User Profile
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Buy Points
  • Users
  • Help
  • Buy Theme
  • SEARCH
Home/ Questions/Q 6192771
In Process

The Archive Base Latest Questions

Editorial Team
  • 0
Editorial Team
Asked: May 24, 20262026-05-24T03:00:06+00:00 2026-05-24T03:00:06+00:00

I’m having this argument about using Cursors in TSQL recently… First of all, I’m

  • 0

I’m having this argument about using Cursors in TSQL recently…

First of all, I’m not a cheerleader in the debate. But every time someone says cursor, there’s always some knucklehead (or 50) who pounce with the obligatory ‘cursors are evil’ mantra. I know SQL-Server was optimized for set-based operations, and maybe cursors truly ARE evil incarnate, but if I wanted to put some objective thought behind that…

Here’s where my mind is going:

  1. Is the only difference between cursors and set operations one of performance?

    Edit: There’s been a good case made for it not being simply a matter of performance — such as running a single batch over-and-over for a list of id’s, or alternatively, executing actual SQL text stored in a table field row-by-row.

  2. Follow-up: do cursors always perform worse?

    • EDIT: @Martin shows a good case where Cursors out-perform set-based operations fairly dramatically. I suspect that this wouldn’t be the kind of thing you’d do too often (before you resorted to some kind of OLAP / Data Warehouse kind of solution), but nonetheless, seems like a case where you really couldn’t live without a cursor.
    • reference to TPC benchmarks suggesting cursors may be more competitive than folks generally believe.
    • reference to memory-usage optimizations for cursors since Sql-Server 2005
  3. Are there any problems you can think of, that cursors are better suited to solve than set-based operations?

    • EDIT: Set-based operations literally cannot Execute stored procedures, etc. (see edit for item 1 above).
    • EDIT: Set-based operations are exponentially slower than row-by-row when it comes to aggregating over large data sets.

  • Article from MSDN explaining their perspective
    of the most common problems people resort to cursors for (and some
    explanation of set-based techniques that would work better.)
  • Microsoft says (vaguely) in the 2008 Transact SQL Reference on MSDN: "…there are times when the results are best processed one row at a time", but the don’t give any examples as to what cases they’re referring to.

Mostly, I’m of a mind to convert cursors to set-based operations in my old code if/as I do any significant upgrades to various applications, as long as there’s something to be gained from it. (I tend toward laziness over purity a lot of the time — i.e., if it ain’t broke, don’t fix it.)

  • 1 1 Answer
  • 0 Views
  • 0 Followers
  • 0
Share
  • Facebook
  • Report

Leave an answer
Cancel reply

You must login to add an answer.

Forgot Password?

Need An Account, Sign Up Here

1 Answer

  • Voted
  • Oldest
  • Recent
  • Random
  1. Editorial Team
    Editorial Team
    2026-05-24T03:00:07+00:00Added an answer on May 24, 2026 at 3:00 am

    To answer your question directly:

    I have yet to encounter a situation where set operations could not do what might otherwise be done with cursors. However, there are situations where using cursors to break a large set problem down into more manageable chunks proves a better solution for purposes of code maintainability, logging, transaction control, and the like. But I doubt there are any hard-and-fast rules to tell you what types of requirements would lead to one solution or the other — individual databases and needs are simply far too variant.

    That said, I fully concur with your “if it ain’t broke, don’t fix it” approach. There is little to be gained by refactoring procedural code to set operations for a procedure that is working just fine. However, it is a good rule of thumb to seek first for a set-based solution and only drop into procedural code when you must. Gut feel? If you’re using cursors more than 20% of the time, you’re doing something wrong.

    And for what I really want to say:

    When I interview programmers, I always throw them a couple of moderately complex SQL questions and ask them to explain how they’d solve them. These are problems that I know can be solved with set operations, and I’m specifically looking for candidates who are able to solve them without procedural approaches (i.e., cursors).

    This is not because I believe there is anything inherently good or more performant in either approach — different situations yield different results. Rather it’s because, in my experience, programmers either get the concept of set-based operations or they do not. If they do not, they will spend too much time developing complex procedural solutions for problems that can be solved far more quickly and simply with set-based operations.

    Conversely, a programmer who gets set-based operations almost never has problems implementing a procedural solution when, indeed, it’s absolutely necessary.

    • 0
    • Reply
    • Share
      Share
      • Share on Facebook
      • Share on Twitter
      • Share on LinkedIn
      • Share on WhatsApp
      • Report

Sidebar

Related Questions

I have a string like this: La Torre Eiffel paragonata all’Everest What PHP function
We're building an app, our first using Rails 3, and we're having to build
link Im having trouble converting the html entites into html characters, (&# 8217;) i
I am reading a book about Javascript and jQuery and using one of the
I'm parsing an RSS feed that has an ’ in it. SimpleXML turns this
I'm making a simple page using Google Maps API 3. My first. One marker
That's pretty much it. I'm using Nokogiri to scrape a web page what has
For some reason, after submitting a string like this Jack’s Spindle from a text
this is what i have right now Drawing an RSS feed into the php,
I have this code to decode numeric html entities to the UTF8 equivalent character.

Explore

  • Home
  • Add group
  • Groups page
  • Communities
  • Questions
    • New Questions
    • Trending Questions
    • Must read Questions
    • Hot Questions
  • Polls
  • Tags
  • Badges
  • Users
  • Help
  • SEARCH

Footer

© 2021 The Archive Base. All Rights Reserved
With Love by The Archive Base

Insert/edit link

Enter the destination URL

Or link to existing content

    No search term specified. Showing recent items. Search or use up and down arrow keys to select an item.