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 相关文章推荐
PHP学习笔记 (1) 环境配置与代码调试
Jun 19 PHP
简单的php数据库操作类代码(增,删,改,查)
Apr 08 PHP
解析用PHP读写音频文件信息的详解(支持WMA和MP3)
May 10 PHP
php数组去重实例及分析
Nov 26 PHP
Linux中用PHP判断程序运行状态的2个方法
May 04 PHP
PHP字符串比较函数strcmp()和strcasecmp()使用总结
Nov 19 PHP
php通过exif_read_data函数获取图片的exif信息
May 21 PHP
php实现购物车功能(下)
Jan 05 PHP
详解php中空字符串和0之间的关系
Oct 23 PHP
php+redis实现多台服务器内网存储session并读取示例
Jan 12 PHP
PHP Socket网络操作类定义与用法示例
Aug 30 PHP
PHP实现数据库统计时间戳按天分组输出数据的方法
Oct 10 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
中文路径导致unitpngfix.js不正常的解决方法
2013/06/26 Javascript
使用js写的一个简易的投票
2013/11/27 Javascript
JavaScript 开发工具webstrom使用指南
2014/12/09 Javascript
JavaScript中的对象的extensible属性介绍
2014/12/30 Javascript
JavaScript获取页面上被选中文字的方法技巧
2015/03/13 Javascript
jquery实现带缩略图的全屏图片画廊效果实例
2015/06/25 Javascript
jQuery往textarea中光标所在位置插入文本的方法
2015/06/26 Javascript
AngularJs实现ng1.3+表单验证
2015/12/10 Javascript
浅谈addEventListener和attachEvent的区别
2016/07/14 Javascript
JS实现本地存储信息的方法(基于localStorage与userData)
2017/02/18 Javascript
聊聊Vue.js的template编译的问题
2017/10/09 Javascript
Angular7创建项目、组件、服务以及服务的使用
2019/02/19 Javascript
微信小程序wx.navigateTo中events属性实现页面间通信传值,数据同步
2019/07/13 Javascript
微信小程序 scroll-view 水平滚动实现过程解析
2019/10/12 Javascript
JS实现简单的表格增删
2020/01/16 Javascript
node.js制作一个简单的登录拦截器
2020/02/10 Javascript
vue-cli 关闭热更新操作
2020/09/18 Javascript
express异步函数异常捕获示例详解
2020/11/30 Javascript
[08:04]TI4西雅图DOTA2前线报道 海涛探访各路人马
2014/07/09 DOTA
在Python中编写数据库模块的教程
2015/04/29 Python
使用Python的package机制如何简化utils包设计详解
2017/12/11 Python
Python实现的读取电脑硬件信息功能示例
2018/05/30 Python
python实现NB-IoT模块远程控制
2018/06/20 Python
python3实现爬取淘宝美食代码分享
2018/09/23 Python
使用Python paramiko模块利用多线程实现ssh并发执行操作
2019/12/05 Python
django实现更改数据库某个字段以及字段段内数据
2020/03/31 Python
VC++笔试题
2014/10/13 面试题
财务信息服务专业自荐书范文
2014/02/08 职场文书
美术国培研修感言
2014/02/12 职场文书
室内拓展活动方案
2014/02/13 职场文书
应聘文员自荐信范文
2014/03/11 职场文书
校庆活动策划方案
2014/06/05 职场文书
办公室务虚会发言材料
2014/10/20 职场文书
java如何实现socket连接方法封装
2021/09/25 Java/Android
Python利用capstone实现反汇编
2022/04/06 Python
postgreSQL数据库基础知识介绍
2022/04/12 PostgreSQL