MySQL 遊標(cursor)簡單應用

來源:互聯網
上載者:User

標籤:os   使用   ar   for   sp   on   c   new   ef   

    MySQL預存程序不可以定義動態遊標(cursor),但是可以使用變數。open -> fetch...into -> close。

    1、聲明一個遊標:

-- define userIdDECLARE userId nvarchar(50) default 0;-- define CURSORDECLARE mycur CURSOR FOR select id from user; -- declare cur stop flag (sql error -> stopCur=1)DECLARE CONTINUE HANDLER FOR SQLSTATE ‘02000‘ SET stopCur=1;DECLARE CONTINUE HANDLER FOR NOT FOUND SET stopCur=1;

    2、open,執行 fetch 迴圈

-- open CURSOROPEN cur;-- Execute only onceFETCH cur INTO userId;WHILE stopCur<>1 DO    BLOCKA:BEGIN       set insertsql=‘‘;       set insertsql=concat(‘insert into newUser(id,name,age) select id,name,age from user where id="‘+userId+‘"‘);        set @sqlinsert=insertSql;       prepare stmtinsert from @sqlinsert;       execute stmtinsert;    END BLOCKA;    -- Execute i-1 times      fetch cur into userId;END WHILE CLOSE cur;

MySQL 遊標(cursor)簡單應用

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.