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

首頁 > 數據庫 > MySQL > 正文

實例解析MySQL中的存儲過程及存儲過程的調用方法

2024-07-24 13:09:28
字體:
來源:轉載
供稿:網友
存儲例程是存儲在數據庫服務器中的一組sql語句,通過在查詢中調用一個指定的名稱來執行這些sql語句命令,下面就以實例解析MySQL中的存儲過程及存儲過程的調用方法:
 

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

一,創建數據庫

mysql>create database db_proc;

二,創建表

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; #設置表引擎和字符集

三、創建存儲過程

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

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

五、查看數據庫中有無加入的數據

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

六、刪除存儲過程

drop procdure 存儲過程名;

七、通用分頁存儲過程代碼及調用

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,         /*每頁記錄數*/   IN   p_page_now     INT,         /*當前頁*/   IN   p_order_string   VARCHAR(128),     /*排序條件(包含ORDER關鍵字,可為空)*/    IN   p_where_string   VARCHAR(1024),    /*WHERE條件(包含WHERE關鍵字,可為空)*/     OUT  p_out_rows     INT          /*輸出記錄總數*/   ) NOT DETERMINISTIC SQL SECURITY DEFINER COMMENT '分頁存儲過程'    BEGIN    /*定義變量*/   DECLARE m_begin_row INT DEFAULT 0;   DECLARE m_limit_string CHAR(64);    /*構造語句*/     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; 

1.取記錄調用:

call pr_pager('表名', '*', 25, 1, '', '', @count_rows); call pr_pager('user', '*', 15, 2, '', 'where id>3', @count_rows); call pr_pager('user', '*', 15, 1, 'group by password order by id desc', '', @count_rows); 

2.調用1后再取條數調用:

select @count_rows;  select @MAIN_STRING //select sql select @COUNT_STRING //seelct count sql 

支持多表級聯 ,分組 :

 

復制代碼代碼如下:

 

call pr_pager('job j left join enter_job ej on j.job_no=ej.job_no','j.*,ej.*','25','1','group by ej.put_away_user order by ej.put_away_user desc','where j.job_table="enter"',@p_out_rows);

 

 

<?php function dump_single_form41report($sys_report_id) {   $this->dbConn->setFetchMode(DB_FETCHMODE_ASSOC);   //SET @a=1;CALL dbpi_report.simpleproc(@a);SELECT @a;   $sql = "CALL dbpi_temp.dumpSingleReportForm41($sys_report_id);";   $result = $this->dbConn->query($sql);   if (mysql_error()) {     die (mysql_error().'<b>:</b> dump_single_form41report(...)['.__LINE__.'];<br>'.$sql);   }   return $result; }  function initQueuePool($sys_report_id, $username){   $this->dbConn->setFetchMode(DB_FETCHMODE_ASSOC);   $this->checkPreviousThread($sys_report_id, $username);    $temptablename = "_".$username."_".$sys_report_id;   $sql = "SET @a=".$sys_report_id.";";   $this->dbConn->query($sql);   $sql = "SET @b='".DB_REPORT.".".$temptablename."';";   $this->dbConn->query($sql);   $sql = "SET @c='".DB_PREPRODUCT."';";   $this->dbConn->query($sql);   $sql = "CALL ".DB_REPORT.".fm41_simpleproc(@a,@b,@c);";   $this->dbConn->query($sql); }  

 
普通的查詢,只返回一個結果集,而存儲過程卻返回至少兩個結果集,其中一個就是存儲過程的執行狀態。我們必須要清除了這個執行狀態以后,才可能再次調用另外一個存儲過程 。

<?php $rs=mysql_query("call pr_pager('change_monitor','*',10,1,'','',@p_out_rows)"); while($rows=mysql_fetch_array($rs)){   echo $rows[Schedule]; } $query=mysql_query("select @p_out_rows"); $v=mysql_fetch_array($query);  can't return a result set in the given context

需要php調用存儲過程,返回一個結果集,發現很困難,找了半天,終于在老外的論壇上找到解決方案,這里本地化一下。
關鍵就是兩點:
1.

define('CLIENT_MULTI_RESULTS', 131072);

2.

$link = mysql_connect("127.0.0.1", "root", "",1,CLIENT_MULTI_RESULTS) or die("Could not connect: ".mysql_error());


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 容城县| 三河市| 顺平县| 丰顺县| 玛多县| 孝昌县| 兴隆县| 徐汇区| 凤冈县| 丹东市| 大荔县| 哈尔滨市| 达日县| 买车| 淮阳县| 万年县| 广饶县| 张家港市| 武宣县| 德兴市| 武安市| 湟中县| 寻乌县| 灵台县| 伊川县| 凤城市| 厦门市| 页游| 屏南县| 弥勒县| 旬邑县| 安新县| 精河县| 巨鹿县| 卢氏县| 赣州市| 特克斯县| 台前县| 电白县| 张家港市| 祥云县|