Cursors on MySQL - Good or Bad

前端 未结 3 1072
悲&欢浪女
悲&欢浪女 2021-02-06 12:27

I 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? D

相关标签:
3条回答
  • 2021-02-06 12:38

    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.

    0 讨论(0)
  • 2021-02-06 12:57

    Just create and fill a temporary table. That is how most RDBMS's implement cursors anyway.

    0 讨论(0)
  • 2021-02-06 12:58

    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.

    0 讨论(0)
提交回复
热议问题