国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數(shù)據(jù)庫 > MySQL > 正文

實例解析MySQL中的存儲過程及存儲過程的調(diào)用方法

2024-07-24 12:44:49
字體:
供稿:網(wǎng)友

mysql在5.1之后增加了存儲過程的功能, 存儲過程運行在mysql內(nèi)部,語句都已經(jīng)編譯好了,速度比sql更快. 存儲過程與mysql相當于shell和linux系統(tǒng)。如果你是程序員的話,那我告訴你存儲過程實際上是一個方法,你只要調(diào)用這個方法,并且輸入它設置好的參數(shù)就可以獲取或者執(zhí)行你想要的操作了. 看了如下存儲過程實例,你會發(fā)現(xiàn)mysql存儲過程和shell很像.
下面存儲過程內(nèi)容為:調(diào)用存儲過程,并且傳入用戶名,密碼參數(shù)。存儲過程會將這她們存儲到process_test表里面.看實例

一,創(chuàng)建數(shù)據(jù)庫

mysql>create database db_proc;

二,創(chuàng)建表

mysql>CREATE TABLE `proc_test` ( `id` tinyint(4) NOT NULL AUTO_INCREMENT, #ID,自動增長 `username` varchar(20) NOT NULL, #用戶名 `password` varchar(20) NOT NULL, #密碼 PRIMARY KEY (`id`) #主鍵 ) ENGINE=MyISAM AUTO_INCREMENT=50 DEFAULT CHARSET=utf8; #設置表引擎和字符集

三、創(chuàng)建存儲過程

create procedure mytest(in name varchar(20),in pwd varchar(20))#定義傳入的參數(shù) begin insert into proc_test(username,password) values(name,pwd);#把傳進來的參數(shù)name和pwd插入表中,別忘記分號 end; #注意這個分號別忘記了create procedure mytest(in name varchar(20),in pwd varchar(20))#定義傳入的參數(shù) begin insert into proc_test(username,password) values(name,pwd);#把傳進來的參數(shù)name和pwd插入表中,別忘記分號 end; #注意這個分號別忘記了

四、測試調(diào)用存儲過程
用法:call 存儲過程名稱(傳入的參數(shù))
call proc_test("絕心是涼白開","www.survivalescaperooms.com")
username為”絕心是涼白開“傳入數(shù)據(jù)庫中,密碼”www.survivalescaperooms.com“

五、查看數(shù)據(jù)庫中有無加入的數(shù)據(jù)

select * from proc_test where username=‘絕心是涼白開';#如果有內(nèi)容說明成功了

六、刪除存儲過程

drop procdure 存儲過程名;

七、通用分頁存儲過程代碼及調(diào)用

DROP PROCEDURE IF EXISTS pr_pager; CREATE PROCEDURE pr_pager( IN p_table_name VARCHAR(1024), /*表名*/ IN p_fields VARCHAR(1024), /*查詢字段*/ IN p_page_size INT, /*每頁記錄數(shù)*/ IN p_page_now INT, /*當前頁*/ IN p_order_string VARCHAR(128), /*排序條件(包含ORDER關(guān)鍵字,可為空)*/ IN p_where_string VARCHAR(1024), /*WHERE條件(包含WHERE關(guān)鍵字,可為空)*/ OUT p_out_rows INT /*輸出記錄總數(shù)*/ ) NOT DETERMINISTIC SQL SECURITY DEFINER COMMENT '分頁存儲過程' BEGIN /*定義變量*/ DECLARE m_begin_row INT DEFAULT 0; DECLARE m_limit_string CHAR(64); /*構(gòu)造語句*/ SET m_begin_row = (p_page_now - 1) * p_page_size; SET m_limit_string = CONCAT(' LIMIT ', m_begin_row, ', ', p_page_size); SET @COUNT_STRING = CONCAT('SELECT COUNT(*) INTO @ROWS_TOTAL FROM ', p_table_name, ' ', p_where_string); SET @MAIN_STRING = CONCAT('SELECT ', p_fields, ' FROM ', p_table_name, ' ', p_where_string, ' ', p_order_string, m_limit_string); /*預處理*/ PREPARE count_stmt FROM @COUNT_STRING; EXECUTE count_stmt; DEALLOCATE PREPARE count_stmt; SET p_out_rows = @ROWS_TOTAL; PREPARE main_stmt FROM @MAIN_STRING; EXECUTE main_stmt; DEALLOCATE PREPARE main_stmt; END;
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 阿克苏市| 阿瓦提县| 商水县| 徐汇区| 亳州市| 即墨市| 灵石县| 绵竹市| 福建省| 丹江口市| 凤山县| 宽城| 深泽县| 潜山县| 马鞍山市| 朝阳县| 和田市| 瑞安市| 奇台县| 镇雄县| 武冈市| 温州市| 栖霞市| 尼木县| 阜新| 鹤庆县| 伽师县| 乌兰浩特市| 呼伦贝尔市| 定安县| 灵武市| 呈贡县| 洛浦县| 龙南县| 蚌埠市| 汉沽区| 辽阳县| 浦城县| 祁东县| 台前县| 格尔木市|