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

 更新时间:2014年12月26日 09:14:05   投稿:shichen2014  
这篇文章主要介绍了PHP调用MySQL存储过程并返回值的方法,较为详细的分析了存储过程的使用技巧,具有一定的参考借鉴价值,需要的朋友可以参考下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

本文实例讲述了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生成zip压缩文件的方法详解

    php生成zip压缩文件的方法详解

    本篇文章是对php生成zip压缩文件的方法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • PHP实现数组的笛卡尔积运算示例

    PHP实现数组的笛卡尔积运算示例

    这篇文章主要介绍了PHP实现数组的笛卡尔积运算,结合实例形式分析了php数组的笛卡尔积运算相关实现与使用技巧,需要的朋友可以参考下
    2017-12-12
  • php中文繁体和简体相互转换的方法

    php中文繁体和简体相互转换的方法

    这篇文章主要介绍了php中文繁体和简体相互转换的方法,涉及php中数组简体繁体对照表的使用技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-03-03
  • phpstorm配置Xdebug进行调试PHP教程

    phpstorm配置Xdebug进行调试PHP教程

    这篇文章主要介绍了使用phpstorm+Xdebug 调试PHP教程,需要的朋友可以参考下
    2014-12-12
  • php获取今日开始时间和结束时间的方法

    php获取今日开始时间和结束时间的方法

    本篇文章实例讲述了php获取今日开始时间和结束时间的方法,具有很好的参考价值,下面跟着小编一起来看下吧
    2017-02-02
  • php邮件发送的两种方式

    php邮件发送的两种方式

    本文就是根据php实现邮件发送的思路,整理下来的一篇文章,在遇到不同问题时给出的不同解决方法,感兴趣的小伙伴们可以参考一下
    2015-10-10
  • PHP实现基数排序的方法详解

    PHP实现基数排序的方法详解

    这篇文章主要介绍了PHP实现基数排序的方法,结合实例形式分析了基数排序的原理、实现方法与相关操作技巧,需要的朋友可以参考下
    2017-12-12
  • php基于单例模式封装mysql类完整实例

    php基于单例模式封装mysql类完整实例

    这篇文章主要介绍了php基于单例模式封装mysql类,结合完整实例形式分析了php使用单例模式封装的mysql类定义与使用方法,需要的朋友可以参考下
    2016-10-10
  • php版微信数据统计接口用法示例

    php版微信数据统计接口用法示例

    这篇文章主要介绍了php版微信数据统计接口用法,结合实例形式分析了php微信数据统计接口功能及相关的使用技巧,需要的朋友可以参考下
    2016-10-10
  • php中try catch捕获异常实例详解

    php中try catch捕获异常实例详解

    这篇文章主要介绍了php中try catch捕获异常的用法,以实例形式详细分析了捕获一个异常与捕获多个异常的方法,有助于更好的处理一些不必要的错误,具有一定的实用价值,需要的朋友可以参考下
    2014-11-11

最新评论

?


http://www.vxiaotou.com