欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

实例解析MySQL中的存储过程及存储过程的调用方法

程序员文章站 2024-02-21 14:33:04
mysql在5.1之后增加了存储过程的功能, 存储过程运行在mysql内部,语句都已经编译好了,速度比sql更快. 存储过程与mysql相当于shell和linux系统。如...

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.jb51.net")
username为”绝心是凉白开“传入数据库中,密码”www.jb51.net“

五、查看数据库中有无加入的数据

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