欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2016年05月13日 14:57:44   作者:hudeyong926  
存儲例程是存儲在數(shù)據(jù)庫服務(wù)器中的一組sql語句,通過在查詢中調(diào)用一個指定的名稱來執(zhí)行這些sql語句命令,下面就以實例解析MySQL中的存儲過程及存儲過程的調(diào)用方法:

mysql在5.1之后增加了存儲過程的功能, 存儲過程運行在mysql內(nèi)部,語句都已經(jīng)編譯好了,速度比sql更快. 存儲過程與mysql相當(dāng)于shell和linux系統(tǒng)。如果你是程序員的話,那我告訴你存儲過程實際上是一個方法,你只要調(diào)用這個方法,并且輸入它設(shè)置好的參數(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; #設(shè)置表引擎和字符集

三、創(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.dbjr.com.cn")
username為”絕心是涼白開“傳入數(shù)據(jù)庫中,密碼”www.dbjr.com.cn“

五、查看數(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,         /*當(dāng)前頁*/ 
  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); 
 
  /*預(yù)處理*/ 
  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.取記錄調(diào)用:

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.調(diào)用1后再取條數(shù)調(diào)用:

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

支持多表級聯(lián) ,分組 :

復(fù)制代碼 代碼如下:

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); 
}  

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

<?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調(diào)用存儲過程,返回一個結(jié)果集,發(fā)現(xiàn)很困難,找了半天,終于在老外的論壇上找到解決方案,這里本地化一下。
關(guān)鍵就是兩點:
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());

相關(guān)文章

  • MySQL查詢重寫插件的使用

    MySQL查詢重寫插件的使用

    這篇文章主要介紹了MySQL查詢重寫插件的使用,幫助大家更好的理解和維護數(shù)據(jù)庫,感興趣的朋友可以了解下
    2020-11-11
  • MySQL的表空間是什么

    MySQL的表空間是什么

    這篇文章主要介紹了MySQL的表空間是什么,幫助大家更好的理解和使用MySQL表的相關(guān)知識,感興趣的朋友可以了解下
    2020-11-11
  • MySQL性能分析工具profile使用教程

    MySQL性能分析工具profile使用教程

    這篇文章主要介紹了MySQL性能分析工具profile使用教程,本文描述了如何使用MySQL profile,不涉及具體的樣例分析,需要的朋友可以參考下
    2014-10-10
  • 關(guān)于mysql自增id,你需要知道的

    關(guān)于mysql自增id,你需要知道的

    這篇文章主要介紹了關(guān)于mysql自增id的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)mysql,感興趣的朋友可以了解下
    2020-08-08
  • 解決mysql模糊查詢索引失效問題的幾種方法

    解決mysql模糊查詢索引失效問題的幾種方法

    我們在使用like %通配符時常常會引起索引失效的問題。本文主要介紹了常見的幾種方法,具有一定的參考價值,感興趣的可以了解一下
    2021-06-06
  • MySQL存儲文本和圖片的方法

    MySQL存儲文本和圖片的方法

    今天小編就為大家分享一篇關(guān)于MySQL存儲文本和圖片的方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • mysql 提示INNODB錯誤的解決方法

    mysql 提示INNODB錯誤的解決方法

    解決The‘InnoDB’feature is disabled; you need MySQL built with ‘InnoDB’ to have it
    2011-09-09
  • MySQL轉(zhuǎn)換Oracle的需要注意的七個事項

    MySQL轉(zhuǎn)換Oracle的需要注意的七個事項

    有很多應(yīng)用項目, 剛起步的時候用MySQL數(shù)據(jù)庫基本上能實現(xiàn)各種功能需求,隨著應(yīng)用用戶的增多,數(shù)據(jù)量的增加,MySQL漸漸地出現(xiàn)不堪重負的情況:連接很慢甚至宕機,于是就有MySQL轉(zhuǎn)換Oracle的需求,應(yīng)用程序也要相應(yīng)做一些修改。
    2010-12-12
  • mysql 8.0.11壓縮包版本安裝教程

    mysql 8.0.11壓縮包版本安裝教程

    這篇文章主要為大家詳細介紹了mysql 8.0.11壓縮包版本安裝教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • mysql installer community 8.0.12.0安裝圖文教程

    mysql installer community 8.0.12.0安裝圖文教程

    這篇文章主要為大家詳細介紹了mysql installer community 8.0.12.0安裝圖文教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-08-08

最新評論