একটি সঞ্চিত পদ্ধতির মধ্যে সেট করা ফলাফল পরিচালনা করতে আমরা একটি কার্সার ব্যবহার করতে পারি। মূলত একটি কার্সার আমাদের একটি প্রশ্ন দ্বারা প্রত্যাবর্তিত সারিগুলির একটি সেট পুনরাবৃত্তি করতে এবং সেই অনুযায়ী প্রতিটি সারি প্রক্রিয়া করার অনুমতি দেয়৷
কারসর -এর ব্যবহার প্রদর্শন করতে৷ MySQL সঞ্চিত পদ্ধতির মধ্যে, আমরা নিম্নোক্ত সঞ্চিত পদ্ধতি তৈরি করছি যা 'student_info' -
নামের টেবিলের নিচে দেখানো মানগুলির উপর ভিত্তি করেmysql> Select * from student_info; +-----+---------+----------+------------+ | id | Name | Address | Subject | +-----+---------+----------+------------+ | 101 | YashPal | Amritsar | History | | 105 | Gaurav | Jaipur | Literature | | 125 | Raman | Shimla | Computers | +-----+---------+----------+------------+ 3 rows in set (0.00 sec)
নিম্নলিখিত ক্যোয়ারীটি 'list_address' নামে একটি পদ্ধতি তৈরি করবে যা টেবিলে সংরক্ষিত সমস্ত ঠিকানার তালিকা প্রদান করবে -
mysql> Delimiter // mysql> CREATE PROCEDURE list_address (INOUT address_list varchar(255)) -> BEGIN -> DECLARE value_finished INTEGER DEFAULT 0; -> DECLARE value_address varchar(100) DEFAULT ""; -> DEClARE address_cursor CURSOR FOR -> SELECT address FROM student_info; -> DECLARE CONTINUE HANDLER -> FOR NOT FOUND SET value_finished = 1; -> OPEN address_cursor; -> get_address: LOOP -> FETCH address_cursor INTO value_address; -> IF value_finished = 1 THEN -> LEAVE get_address; -> END IF; -> SET address_list = CONCAT(value_address,";",address_list); -> END LOOP get_address; -> CLOSE address_cursor; -> END // Query OK, 0 rows affected (0.00 sec)
এখন, আমরা যখন এই পদ্ধতিটি চালু করি তখন আমরা নীচের ফলাফল দেখতে পাব −
৷mysql> DELIMITER ; mysql> Set @address_list = ""; Query OK, 0 rows affected (0.00 sec) mysql> CALL list_address(@address_list); Query OK, 0 rows affected (0.00 sec) mysql> Select @address_list; +-------------------------+ | @address_list | +-------------------------+ | Shimla;Jaipur;Amritsar; | +-------------------------+ 1 row in set (0.00 sec)