Bug #3052 Rollback in stored procedure doesn't close cursor
Submitted: 3 Mar 2004 2:46 Modified: 24 Apr 2006 7:00
Reporter: Peter Gulutzan Email Updates:
Status: Verified Impact on me:
None 
Category:MySQL Server: Stored Routines Severity:S3 (Non-critical)
Version:5.1 OS:Linux (SuSE 8.2)
Assigned to: CPU Architecture:Any
Tags: cursor, rollback

[3 Mar 2004 2:46] Peter Gulutzan
Description:
ROLLBACK doesn't close open cursors. 
 
This applies only for ROLLBACK statements that occur within stored procedures, 
after a cursor is OPENed, before it is CLOSEd. 
 

How to repeat:
 mysql> delimiter // 
 mysql> create table t (s1 int)// 
 Query OK, 0 rows affected (0.26 sec) 
  
 mysql> insert into t values (55)// 
 Query OK, 1 row affected (0.00 sec) 
  
 mysql> create procedure p2 () begin 
  declare v int; 
  declare x cursor for select s1 from t; 
  open x; 
  rollback; 
  fetch x into v; 
  set @x = v; 
  end;// 
 Query OK, 0 rows affected (0.00 sec) 
  
 mysql> call p2()// 
 Query OK, 0 rows affected, 1 warning (0.01 sec) 
  
 mysql> select @x// 
 +------+ 
 | @x   | 
 +------+ 
 | 55   | 
 +------+ 
 1 row in set (0.00 sec) 
  
 It's clear that the FETCH succeeded, even though 
 there was a ROLLBACK just before it. 

Suggested fix:
Nothing immediate is expected. The behaviour is not intentional, 
but apparently we'll have to wait for the new parser.
[15 Mar 2006 13:33] Per-Erik Martin
This can be fixed. Since it will be a change in behaviour, it must be in 5.1 (or later).
At the same time, the behaviour of COMMIT should be fixed the same way. In this case we should add the WITH[OUT] HOLD syntax for DECLARE CURSOR and close all not held cursors on COMMIT.
[22 Aug 2006 15:02] Konstantin Osipov
This is too big to be fixed in 5.0, will be fixed in 5.1
[11 Nov 2017 18:17] Federico Razzoli
Identical behaviour in 8.0.3.
[24 Jan 18:57] Jammes brown
Iptv Century It's very interesting, I realized you can fix this https://iptvcentury.com
[24 Jan 18:57] Jammes brown
HORLOLUJO RELOJES REPLICAS SUIZOS SUPER CLON Luxury Replica Watches
 http://horlolujo.com
[24 Jan 18:58] Jammes brown
Net iptv It's very interesting, I realized you can fix this only when you truly want  to use it in usa. I am looking forward to the https://netiptv.store
[24 Jan 23:21] Jammes brown
Iptv Uk It's very interesting, I realized you can fix this only when you truly want  to use it in uk . I am looking forward to the next Discount http://tivilitopia.com
[15 Feb 1:24] Morgan Paul
German iptv  It's very interesting, I realized you can fix this only when you truly want to use it in Germany https://iptevia.com
[15 Feb 1:25] Morgan Paul
IPTV Nederland https://Darktv.co
[27 Feb 13:56] Morgan Paul
IPTV Nederland services represent a major IPTV KOPEN https://Darktv.co/home
[27 Feb 13:56] Morgan Paul
Discover the Best IPTV UK Provider: Say goodbye to costly cables and endless buffering! https://xtremehd-uk.uk
[9 Mar 6:56] Jesus Christ
Troubleshoot AI Apps  https://www.troubleshoot.dev/
[9 Mar 6:57] Jesus Christ
Latest Merch Deals  https://latestmerch.com/
[9 Mar 6:58] Jesus Christ
Remote Software Jobs https://programable.com/
[9 Mar 6:59] Jesus Christ
attorney jobs  https://attorney.work/
[9 Mar 6:59] Jesus Christ
authentic jerseys store   https://authenticjerseysstore.com/
[24 Mar 6:34] bestiptv providers
Best IPTV Providers IS the Best iptv subscription service in the worldwide https://bestiptvproviders.net