当前位置:首页 > PHP教程 > php高级应用 > 列表

php怎么运行存储过程?php存储过程调用实例代码

发布:smiling 来源: PHP粉丝网  添加日期:2018-07-03 14:33:23 浏览: 评论:0 

代码如下:

  1. //比如要调用的存储过程为gxtj(a,b)  
  2. $db=new mysqli("localhost","ssss","aaaaa","bbbb");  
  3. mysqli_query($db,"SET NAMES utf8");  
  4. $result=$db->query("call gxtj($year,$jd)"); // gxtj是mysql的存储过程名称 [color=gray][/color]  
  5. while$row = $result->fetch_array(MYSQLI_ASSOC)) //完成从返回结果集中取出一行  
  6. {  //phpfensi.com 
  7. while ($key=key($row)){ //依次取得字段名  
  8. $value=current($row); //依次取得字段值  
  9. }  
  10. }  

实例一:无参的存储过程,代码如下:

$sql = "call test.myproce();";

mysql_query($sql);//调用myproce的存储过程,则数据库中将增加一条新记录。

实例二:传入参数的存储过程,代码如下:

  1. $sql = " 
  2. create procedure myproce2(in score int) 
  3. begin 
  4. if score >= 60 then 
  5. select 'pass' 
  6. else 
  7. select 'no' 
  8. end if
  9. end;  
  10. "; 
  11. mysql_query($sql);//创建一个myproce2的存储过程 
  12. $sql = "call test.myproce2(70);"
  13. mysql_query($sql);//调用myproce2的存储过程,看不到效果,可以在cmd下看到结果。 

实例三:传出参数的存储过程,代码如下:

  1. $sql = " 
  2. create procedure myproce3(out score int) 
  3. begin 
  4. set score=100; 
  5. end;  
  6. "; 
  7. mysql_query($sql);//创建一个myproce3的存储过程 
  8. $sql = "call test.myproce3(@score);"
  9. mysql_query($sql);//调用myproce3的存储过程 
  10. $result = mysql_query('select @score;'); 
  11. $array = mysql_fetch_array($result); 
  12. echo ' 
  13. 'print_r($array); 

实例四:传出参数的inout存储过程,代码如下:

  1. $sql = " 
  2. create procedure myproce4(inout sexflag int) 
  3. begin 
  4. SELECT * FROM user WHERE sex = sexflag; 
  5. end;  
  6. "; 
  7. mysql_query($sql);//创建一个myproce4的存储过程 
  8. $sql = "set @sexflag = 1"
  9. mysql_query($sql);//设置性别参数为1 
  10. $sql = "call test.myproce4(@sexflag);"
  11. mysql_query($sql);//调用myproce4的存储过程,在cmd下面看效果 

实例五:使用变量的存储过程,代码如下:

  1. $sql = " 
  2. create procedure myproce5(in a int,in b int) 
  3. begin 
  4. declare s int default 0; 
  5. set s=a+b; 
  6. select s; 
  7. end;  
  8. "; 
  9. mysql_query($sql);//创建一个myproce5的存储过程 
  10. $sql = "call test.myproce5(4,6);"
  11. mysql_query($sql);//调用myproce5的存储过程,在cmd下面看效果 

实例六:case语法,代码如下:

  1. $sql = " 
  2. create procedure myproce6(in score int) 
  3. begin 
  4. case score 
  5. when 60 then select '及格' 
  6. when 80 then select '及良好' 
  7. when 100 then select '优秀' 
  8. else select '未知分数' 
  9. end case
  10. end;  
  11. "; 
  12. mysql_query($sql);//创建一个myproce6的存储过程 
  13. $sql = "call test.myproce6(100);"
  14. mysql_query($sql);//调用myproce6的存储过程,在cmd下面看效果 

实例七:循环语句,代码如下:

  1. $sql = " 
  2. create procedure myproce7() 
  3. begin 
  4. declare i int default 0; 
  5. declare j int default 0; 
  6. while i<10 do 
  7. set j=j+i; 
  8. set i=i+1; 
  9. end while
  10. select j; 
  11. end;  
  12. "; 
  13. mysql_query($sql);//创建一个myproce7的存储过程 
  14. $sql = "call test.myproce7();"
  15. mysql_query($sql);//调用myproce7的存储过程,在cmd下面看效果 

实例八:repeat语句,代码如下:

  1. $sql = "  
  2. create procedure myproce8() 
  3. begin 
  4. declare i int default 0; 
  5. declare j int default 0; 
  6. repeat 
  7. set j=j+i; 
  8. set i=i+1; 
  9. until j>=10 
  10. end repeat; 
  11. select j; 
  12. end;  
  13. "; 
  14. mysql_query($sql);//创建一个myproce8的存储过程 
  15. $sql = "call test.myproce8();"
  16. mysql_query($sql);//调用myproce8的存储过程,在cmd下面看效果 

实例九:loop语句,代码如下:

  1. loop_label:loop 
  2. set s=s+i; 
  3. set i=i+1; 
  4. if i>=5 then 
  5. leave loop_label; 
  6. end if
  7. end loop; 
  8. select s; 
  9. end;  
  10. "; 
  11. mysql_query($sql);//创建一个myproce9的存储过程 
  12. $sql = "call test.myproce9();"
  13. mysql_query($sql);//调用myproce9的存储过程,在cmd下面看效果 

实例十:删除存储过程,代码如下:

mysql_query("drop procedure if exists myproce");//删除test的存储过程

实例十:存储过程中的游标

总结中。

Tags: php运行存储 php存储过程

分享到: