實(shí)例解析MySQL中的存儲(chǔ)過(guò)程及存儲(chǔ)過(guò)程的調(diào)用方法
mysql在5.1之后增加了存儲(chǔ)過(guò)程的功能, 存儲(chǔ)過(guò)程運(yùn)行在mysql內(nèi)部,語(yǔ)句都已經(jīng)編譯好了,速度比sql更快. 存儲(chǔ)過(guò)程與mysql相當(dāng)于shell和linux系統(tǒng)。如果你是程序員的話,那我告訴你存儲(chǔ)過(guò)程實(shí)際上是一個(gè)方法,你只要調(diào)用這個(gè)方法,并且輸入它設(shè)置好的參數(shù)就可以獲取或者執(zhí)行你想要的操作了. 看了如下存儲(chǔ)過(guò)程實(shí)例,你會(huì)發(fā)現(xiàn)mysql存儲(chǔ)過(guò)程和shell很像.
下面存儲(chǔ)過(guò)程內(nèi)容為:調(diào)用存儲(chǔ)過(guò)程,并且傳入用戶名,密碼參數(shù)。存儲(chǔ)過(guò)程會(huì)將這她們存儲(chǔ)到process_test表里面.看實(shí)例
一,創(chuàng)建數(shù)據(jù)庫(kù)
mysql>create database db_proc;
二,創(chuàng)建表
mysql>CREATE TABLE `proc_test` ( `id` tinyint(4) NOT NULL AUTO_INCREMENT, #ID,自動(dòng)增長(zhǎng) `username` varchar(20) NOT NULL, #用戶名 `password` varchar(20) NOT NULL, #密碼 PRIMARY KEY (`id`) #主鍵 ) ENGINE=MyISAM AUTO_INCREMENT=50 DEFAULT CHARSET=utf8; #設(shè)置表引擎和字符集
三、創(chuàng)建存儲(chǔ)過(guò)程
create procedure mytest(in name varchar(20),in pwd varchar(20))#定義傳入的參數(shù) begin insert into proc_test(username,password) values(name,pwd); #把傳進(jìn)來(lái)的參數(shù)name和pwd插入表中,別忘記分號(hào) end; #注意這個(gè)分號(hào)別忘記了 create procedure mytest(in name varchar(20),in pwd varchar(20))#定義傳入的參數(shù) begin insert into proc_test(username,password) values(name,pwd); #把傳進(jìn)來(lái)的參數(shù)name和pwd插入表中,別忘記分號(hào) end; #注意這個(gè)分號(hào)別忘記了
四、測(cè)試調(diào)用存儲(chǔ)過(guò)程
用法:call 存儲(chǔ)過(guò)程名稱(chēng)(傳入的參數(shù))
call proc_test("絕心是涼白開(kāi)","www.dhdzp.com")
username為”絕心是涼白開(kāi)“傳入數(shù)據(jù)庫(kù)中,密碼”www.dhdzp.com“
五、查看數(shù)據(jù)庫(kù)中有無(wú)加入的數(shù)據(jù)
select * from proc_test where username=‘絕心是涼白開(kāi)';#如果有內(nèi)容說(shuō)明成功了
六、刪除存儲(chǔ)過(guò)程
drop procdure 存儲(chǔ)過(guò)程名;
七、通用分頁(yè)存儲(chǔ)過(guò)程代碼及調(diào)用
DROP PROCEDURE IF EXISTS pr_pager;
CREATE PROCEDURE pr_pager(
IN p_table_name VARCHAR(1024), /*表名*/
IN p_fields VARCHAR(1024), /*查詢(xún)字段*/
IN p_page_size INT, /*每頁(yè)記錄數(shù)*/
IN p_page_now INT, /*當(dāng)前頁(yè)*/
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 '分頁(yè)存儲(chǔ)過(guò)程'
BEGIN
/*定義變量*/
DECLARE m_begin_row INT DEFAULT 0;
DECLARE m_limit_string CHAR(64);
/*構(gòu)造語(yǔ)句*/
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
支持多表級(jí)聯(lián) ,分組 :
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);
}
普通的查詢(xún),只返回一個(gè)結(jié)果集,而存儲(chǔ)過(guò)程卻返回至少兩個(gè)結(jié)果集,其中一個(gè)就是存儲(chǔ)過(guò)程的執(zhí)行狀態(tài)。我們必須要清除了這個(gè)執(zhí)行狀態(tài)以后,才可能再次調(diào)用另外一個(gè)存儲(chǔ)過(guò)程 。
<?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)用存儲(chǔ)過(guò)程,返回一個(gè)結(jié)果集,發(fā)現(xiàn)很困難,找了半天,終于在老外的論壇上找到解決方案,這里本地化一下。
關(guān)鍵就是兩點(diǎ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());
- mysql 存儲(chǔ)過(guò)程中變量的定義與賦值操作
- mysql存儲(chǔ)過(guò)程詳解
- mysql存儲(chǔ)過(guò)程 游標(biāo) 循環(huán)使用介紹
- MySQL存儲(chǔ)過(guò)程例子(包含事務(wù),輸出參數(shù),嵌套調(diào)用)
- MySql存儲(chǔ)過(guò)程與函數(shù)詳解
- mysql 查詢(xún)數(shù)據(jù)庫(kù)中的存儲(chǔ)過(guò)程與函數(shù)的語(yǔ)句
- mysql存儲(chǔ)過(guò)程 在動(dòng)態(tài)SQL內(nèi)獲取返回值的方法詳解
- MySQL 存儲(chǔ)過(guò)程中執(zhí)行動(dòng)態(tài)SQL語(yǔ)句的方法
- MySQL存儲(chǔ)過(guò)程中游標(biāo)循環(huán)的跳出和繼續(xù)操作示例
- Mysql存儲(chǔ)過(guò)程和函數(shù)區(qū)別介紹
- mysql存儲(chǔ)過(guò)程原理與用法詳解
相關(guān)文章
MySQL如何查詢(xún)Binlog 生成時(shí)間
這篇文章主要介紹了MySQL如何查詢(xún)Binlog 生成時(shí)間,通過(guò)讀取 Binlog FORMAT_DESCRIPTION_EVENT header 時(shí)間戳來(lái)實(shí)現(xiàn)讀取 Binlog 生產(chǎn)時(shí)間,本文給大家詳細(xì)講解,需要的朋友可以參考下2023-03-03
windows環(huán)境下Mysql中文亂碼問(wèn)題解決方法
在搭建Mysql環(huán)境的時(shí)候遇到了中文亂碼問(wèn)題,下面與大家分享下具體的解決方法,感興趣的朋友可以參考下哈,希望對(duì)大家有所幫助2013-06-06
mysql 的indexof函數(shù)用法說(shuō)明
這篇文章主要介紹了mysql 的indexof函數(shù)用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-12-12
MySQL數(shù)據(jù)庫(kù)存儲(chǔ)引擎介紹及數(shù)據(jù)庫(kù)的操作詳解
mysql面試中最常問(wèn)的問(wèn)題之一:小伙子,你說(shuō)一下你們公司用的存儲(chǔ)引擎,以及你知道有哪些存儲(chǔ)引擎和他們之間的區(qū)別? 所以下面這篇文章主要給大家介紹了關(guān)于Mysql存儲(chǔ)引擎的相關(guān)資料,需要的朋友可以參考下2022-08-08
CentOS 7.0如何啟動(dòng)多個(gè)MySQL實(shí)例教程(mysql-5.7.21)
這篇文章主要給大家介紹了關(guān)于CentOS 7.0如何啟動(dòng)多個(gè)MySQL實(shí)例(mysql-5.7.21)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起看看吧。2018-03-03
MySQL高級(jí)進(jìn)階sql語(yǔ)句總結(jié)大全
這篇文章主要給大家介紹了關(guān)于MySQL高級(jí)進(jìn)階sql語(yǔ)句的相關(guān)資料,文中通過(guò)圖文以及實(shí)例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2022-03-03

