MySQL存儲(chǔ)過程的查詢命令介紹
select name from mysql.proc where db=’數(shù)據(jù)庫(kù)名’;
或者
select routine_name from information_schema.routines where routine_schema=’數(shù)據(jù)庫(kù)名’;
或者
show procedure status where db=’數(shù)據(jù)庫(kù)名’;SHOW CREATE PROCEDURE 數(shù)據(jù)庫(kù).存儲(chǔ)過程名;
補(bǔ)充:MySQL存儲(chǔ)過程-循環(huán)遍歷查詢到的結(jié)果集
1、創(chuàng)建存儲(chǔ)過程根據(jù)MySQL的語法創(chuàng)建存儲(chǔ)過程,要注意的是如果循環(huán)遍歷查詢到的結(jié)果集,取出結(jié)果集中的數(shù)據(jù)做操作。
CREATE DEFINER=`root`@`%` PROCEDURE `alter_view_counts`()BEGIN #聲明結(jié)束標(biāo)識(shí) DECLARE end_flag int DEFAULT 0; DECLARE albumId bigint; #聲明游標(biāo) album_curosr DECLARE album_curosr CURSOR FOR SELECT album_id FROM album; #設(shè)置終止標(biāo)志 DECLARE CONTINUE HANDLER FOR NOT FOUND SET end_flag=1; #打開游標(biāo) OPEN album_curosr; #遍歷游標(biāo) REPEAT #獲取當(dāng)前游標(biāo)指針記錄,取出值賦給自定義的變量 FETCH album_curosr INTO albumId; #利用取到的值進(jìn)行數(shù)據(jù)庫(kù)的操作 UPDATE album SET album.views_count= (SELECT SUM(light_chat.views_count) FROM `light_chat` WHERE light_chat.album_id = albumId) WHERE album.album_id = albumId; # 根據(jù) end_flag 判斷是否結(jié)束 UNTIL end_flag END REPEAT; #關(guān)閉游標(biāo) close album_curosr; END2,調(diào)用存儲(chǔ)過程
CALL alter_view_counts()
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. MySQL Delete 刪數(shù)據(jù)后磁盤空間未釋放的原因2. MySql如何使用not in實(shí)現(xiàn)優(yōu)化3. MySQL中文亂碼問題解決方案4. 淺談數(shù)據(jù)庫(kù)日期類型字段設(shè)計(jì)應(yīng)該如何選擇5. MySQL性能優(yōu)化之一條SQL在MySQL中執(zhí)行的過程詳解6. Microsoft Office Access隱藏和顯示字段的方法7. MySQL Innodb 存儲(chǔ)結(jié)構(gòu) 和 存儲(chǔ)Null值 用法詳解8. mysql存儲(chǔ)過程游標(biāo)之loop循環(huán)解讀9. MySQL忘記root密碼以及遠(yuǎn)程無法連接的解決方法10. MySQL索引知識(shí)的一些小妙招總結(jié)
