PHP调用MySQL存储过程并返回值的方法


Posted in PHP onDecember 26, 2014

本文实例讲述了php中调用执行mysql存储过程然后返回由存储过程返回的值,分享给大家供大家参考。具体分析如下:

调用存储过程的方法.

a。如果存储过程有 IN/INOUT参数,声明一个变量,输入参数给存储过程,该变量是一对,一个php变量,也可以不必,只是没有php变量时,没有办法进行动态输入,一个Mysql变量.

b。如果存储过程有OUT变量,声明一个Mysql变量,mysql变量的声明比较特殊,必须让mysql服务器知道此变量的存在,其实也就是执行一条mysql语句,入set @mysqlvar=$phpvar ;

c。使用mysql_query()/mysql_db_query()执行mysql 变量声明语句。

代码如下:

mysql_query("set @mysqlvar=$pbpvar");

这样,在mysql服务器里面就有一个变量,@mysqlar,如果时IN参数,那么其值可以有phpar传入.

例,利用mysqli函数实例,我们先可在mysql创建一个存储过程,代码如下:

mysql> delimiter // 

mysql> CREATE PROCEDURE employee_list (OUT param1 INT) 

    -> BEGIN 

    ->   SELECT COUNT(*) INTO param1 FROM t; 

    -> END 

    -> // 

Query OK, 0 rows affected (0.00 sec)

然后在php中如下写,代码如下:
<h1>Employee listing</h1> 

<form method="post" > 

<p>Enter Department ID: 

<input type="text" name="dept_id" size="4"> 

<input type="submit" name="submit" value="submit"><p> 

</form> 

<?php 

$hostname = "localhost"; 

$username = "root"; 

$password = "secret"; 

$database = "prod"; 

if (IsSet ($_POST['submit'])) { 

     $dbh = new mysqli($hostname, $username, $password, $database); 

     /* check connection */ 

     if (mysqli_connect_errno()) { 

          printf("Connect failed: %sn", mysqli_connect_error()); 

          exit (); 

     } 

     $dept_id = $_POST['dept_id']; 

     if ($result_set = $dbh->query("call employee_list( $dept_id )")) { 

          print ('<table border="1" width="30%"> <tr> '. 

               '<td>Employee_id</td><td>Surname</td><td>Firstname</td></tr>');

          while ($row = $result_set->fetch_object()) { 

               printf("<tr><td>%s</td><td>%s</td><td>%s</td></tr>n",  

                      $row->employee_id, $row->surname, $row->firstname); 

          } 

     } else { 

          printf("<p>Error:%d (%s) %sn", mysqli_errno($dbh),  

                 mysqli_sqlstate($dbh), mysqli_error($dbh)); 

     } 

     print ("</table> "); 

     $dbh->close(); 

} 

?>

核心代码就是,代码如下:
$result_set = $dbh->query("call employee_list( $dept_id )")

这句employee_list是我们的mysql存储过程.

希望本文所述对大家的php程序设计有所帮助。

PHP 相关文章推荐
使用TinyButStrong模板引擎来做WEB开发
Mar 16 PHP
PHP array_flip() 删除重复数组元素专用函数
May 16 PHP
php中flush()、ob_flush()、ob_end_flush()的区别介绍
Feb 17 PHP
几道坑人的PHP面试题 试试看看你会不会也中招
Aug 19 PHP
PHP实现定时执行任务的方法
Oct 05 PHP
php计算两个文件相对路径的方法
Mar 14 PHP
WordPres对前端页面调试时的两个PHP函数使用小技巧
Dec 22 PHP
浅谈mysql_query()函数的返回值问题
Sep 05 PHP
PHP基于SMTP协议实现邮件发送实例代码
Apr 27 PHP
Laravel解决nesting level错误和隐藏index.php的问题
Oct 12 PHP
Laravel基础_关于view共享数据的示例讲解
Oct 14 PHP
浅谈如何提高PHP代码质量之端到端集成测试
May 28 PHP
php+ajax实时输入自动搜索匹配的方法
Dec 26 #PHP
windows下配置php5.5开发环境及开发扩展
Dec 25 #PHP
PHP中require和include路径问题详解
Dec 25 #PHP
Yii框架调试心得--在页面输出执行sql语句
Dec 25 #PHP
Web程序工作原理详解
Dec 25 #PHP
php更新mysql后获取改变行数的方法
Dec 25 #PHP
php常见的魔术方法详解
Dec 25 #PHP
You might like
PHP+Mysql+jQuery实现发布微博程序 php篇
2015/10/15 PHP
phpstudy默认不支持64位php的解决方法
2017/02/20 PHP
PHP命名空间namespace的定义方法详解
2017/03/29 PHP
jquery构造器的实现代码小结
2011/05/16 Javascript
js在数组中删除重复的元素自保留一个(两种实现思路)
2014/08/22 Javascript
js密码强度校验
2015/11/10 Javascript
不想让浏览器运行javascript脚本的方法
2015/11/20 Javascript
jQuery formValidator表单验证
2016/01/07 Javascript
jQuery unbind 删除绑定事件详解
2016/05/24 Javascript
jQuery插件扩展extend的简单实现原理
2016/06/24 Javascript
更靠谱的H5横竖屏检测方法(js代码)
2016/09/13 Javascript
Javascript中关于Array.filter()的妙用详解
2016/12/04 Javascript
JSON 数据详解及实例代码分析
2017/01/20 Javascript
VueJS 集成 Medium Editor的示例代码 (自定义编辑器按钮)
2017/08/24 Javascript
Node.js实现连接mysql数据库功能示例
2017/09/15 Javascript
React中嵌套组件与被嵌套组件的通信过程
2018/07/11 Javascript
vue兄弟组件传递数据的实例
2018/09/06 Javascript
微信小程序点击view动态添加样式过程解析
2020/01/21 Javascript
[01:04:30]Fnatic vs Mineski 2018国际邀请赛小组赛BO2 第二场 8.17
2018/08/18 DOTA
python如何提取英语pdf内容并翻译
2020/03/03 Python
Python读取VOC中的xml目标框实例
2020/03/10 Python
python,Java,JavaScript实现indexOf
2020/09/09 Python
pip/anaconda修改镜像源,加快python模块安装速度的操作
2021/03/04 Python
CSS Grid布局教程之网格单元格布局
2014/12/30 HTML / CSS
详解CSS3中字体平滑处理和抗锯齿渲染
2017/03/29 HTML / CSS
健康监测猫砂:Pretty Litter
2017/05/25 全球购物
南京某公司笔试题
2013/01/27 面试题
销售心得体会
2014/01/02 职场文书
婚礼主持词开场白
2014/03/13 职场文书
推广普通话演讲稿
2014/05/23 职场文书
驾驶员安全责任书
2014/07/22 职场文书
大学生党员个人剖析材料
2014/10/08 职场文书
市场部经理岗位职责
2015/02/02 职场文书
质量承诺书格式范文
2015/04/28 职场文书
和领导吃饭祝酒词
2015/08/11 职场文书
Python 流媒体播放器的实现(基于VLC)
2021/04/28 Python