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 相关文章推荐
一个ubbcode的函数,速度很快.
Oct 09 PHP
PHP 数据结构 算法描述 冒泡排序 bubble sort
Jul 10 PHP
PHP 年龄计算函数(精确到天)
Jun 07 PHP
PHP 图片水印类代码
Aug 27 PHP
PHP面向对象之旅:深入理解static变量与方法
Jan 06 PHP
PHP5中实现多态的两种方法实例分享
Apr 21 PHP
php实现的九九乘法口诀表简洁版
Jul 28 PHP
用 Composer构建自己的 PHP 框架之构建路由
Oct 30 PHP
PHP中创建和验证哈希的简单方法实探
Jul 06 PHP
PHP中把对象数组转换成普通数组的方法
Jul 10 PHP
php+croppic.js实现剪切上传图片功能
Aug 14 PHP
thinkphp5.1框架模板赋值与变量输出示例
May 25 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
星际初学者游戏中永远要做的事
2020/03/04 星际争霸
PHP 获取客户端真实IP地址多种方法小结
2010/05/15 PHP
php版阿里大于(阿里大鱼)短信发送实例详解
2016/11/30 PHP
PHP生成图片缩略图类示例
2017/01/12 PHP
JavaScript 学习笔记(十二) dom
2010/01/21 Javascript
JS 树形递归实例代码
2010/05/18 Javascript
jQuery EasyUI API 中文文档 - Calendar日历使用
2011/10/19 Javascript
分享一个用Mootools写的鼠标滑过进度条改变进度值的实现代码
2011/12/12 Javascript
基于jquery扩展漂亮的CheckBox(自己编写)
2013/11/19 Javascript
PHP+mysql+Highcharts生成饼状图
2015/05/04 Javascript
javascript封装简单实现方法
2015/08/11 Javascript
JavaScript中利用jQuery绑定事件的几种方式小结
2016/03/06 Javascript
解析利用javascript如何判断一个数为素数
2016/12/08 Javascript
微信小程序 flex实现导航实例详解
2017/04/26 Javascript
ES6入门教程之Iterator与for...of循环详解
2017/05/17 Javascript
Angular5给组件本身的标签添加样式class的方法
2018/04/07 Javascript
微信小程序如何实现点击图片放大功能
2020/01/21 Javascript
python实现杨辉三角思路
2017/07/14 Python
win10 64bit下python NLTK安装教程
2018/09/19 Python
Pycharm 设置默认头的图文教程
2019/01/17 Python
python中如何实现将数据分成训练集与测试集的方法
2019/09/13 Python
python scipy卷积运算的实现方法
2019/09/16 Python
python的scipy实现插值的示例代码
2019/11/12 Python
python 多维高斯分布数据生成方式
2019/12/09 Python
Python线程threading模块用法详解
2020/02/26 Python
Python使用进程Process模块管理资源
2020/03/05 Python
python修改微信和支付宝步数的示例代码
2020/10/12 Python
一篇文章带你搞定Ubuntu中打开Pycharm总是卡顿崩溃
2020/11/02 Python
Reebonz中国官网:新加坡奢侈品购物网站
2017/03/17 全球购物
大学生职业生涯规划范文
2014/01/08 职场文书
2014世界杯球队球队口号
2014/06/05 职场文书
离婚协议书范本(2014版)
2014/09/28 职场文书
2015年数学教师工作总结
2015/05/20 职场文书
大学自主招生自荐信(2016精选篇)
2016/01/28 职场文书
高二化学教学反思
2016/02/22 职场文书
使用ORM新增数据在Mysql中的操作步骤
2021/07/26 MySQL