Cursors on MySQL - Good or Bad [closed]
Want to improve this question? Update the question so it can be answered with facts and citations by editing this post.
Closed 1 year ago.
Improve this questionI have always heard people saying bad about using cursors and this is especially in Microsoft SQL Server as they are very slow.
Is this the case with Cursors on MySQL as well? Does cursors in MySQL reduce performance as well? Can someone please advice on the usage of cursors in MySQL?
Most modern databases (including MySQL) are designed to perform set based operations. The problem with cursors is that they perform row based (or procedural) operations. Because of this you will almost always see a performance hits when you are using cursors to do a job that can be done without cursors on a modern DBMS.
Take a look at this article, which does a decent job going over the two. It is written with SQL Server in mind but most of the concepts apply.
Just create and fill a temporary table. That is how most RDBMS's implement cursors anyway.
Cursors by nature are Iterative - they are definitely going to be slower irrespective of any database type. You should therefore do whatever to avoid them and try to find solutions using SQL queries. They are however there for problems which cannot be solved with queries - so use them only when absolutely necessary.
精彩评论