php调用MySQL存储过程的方法集合(推荐)

 更新时间:2013年07月03日 11:46:26   作者:  
本篇文章是对php调用MySQL存储过程的方法进行了集合与汇总,需要的朋友参考下
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

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

类型一:调用带输入、输出类型参数的方法
复制代码 代码如下:

$returnValue = '';
try {
 mysql_query ( "set @Return" );
 $spname = 'P__Test_GetInfo1';
 mysql_query ( "call $spname(@Return, '{$userId}', '{$pwd}')" ) or die ( "[$spname]Query failed:" . mysql_error () );
 $result_return = mysql_query ( "select @Return" );
 $row_return = mysql_fetch_row ( $result_return );
 $returnValue = $row_return [0];
} catch ( Exception $e ) {
 echo $e;
}
echo $returnValue; //输出来自存储过程中输出的变量

类型二:调用带多个输出类型和多个输入类型参数的方法
复制代码 代码如下:

$userId = 0;
try{
    mysql_query("set @Message");
    mysql_query("set @Id");
    mysql_query("call P__Test_Login(@Message, @Id, '{$userId}', '{$pwd}')", $conn) or die("Query failed:".mysql_error());
    $result_mess = mysql_query("select @Message");
    $result_uid = mysql_query("select @Id");
    $row_mess = mysql_fetch_row($result_mess);
    $row_uid = mysql_fetch_row($result_uid);
    $Proc_Error = $row_mess[0];
    $uId = $row_uid[0];
}
catch( Exception $e )
{
   echo $e;
}
echo 'proc return message:'$Proc_Error.'<br/>'; //输出来自存储过程中输出的变量
echo 'User id:'.$uId; //获取用户id

类型三:调用带返回结果集的方法
复制代码 代码如下:

try {
 $spname = 'P__Test_GetData';
 $query = mysql_query ( "call $spname()", $conn ) or die ( "[$spname]Query failed:".mysql_error() );
 while ( $row = mysql_fetch_array ( $query ) ) {
  echo $row ['ProvinceID'].'::'.$row ['ProvinceName']; //输出数据集
 }

} catch ( Exception $e ) {
 echo $e;
}

类型四:调用带返回多个结果集的方法(目前只能通过mysqli来实现~~)
复制代码 代码如下:

//PHP
$rows = array (); 
$db = new mysqli($server,$user,$psd,$dbname); 
if (mysqli_connect_errno()){ 
    $this->message('Can not connect to MySQL server'); 

$db->query("SET NAMES UTF8"); 
$db->query("SET @Message");
if($db->real_query("call P__Test_GetData2(@Message)")){ 
    do{ 
        if($result = $db->store_result()){ 
            while ($row = $result->fetch_assoc()){ 
                array_push($rows, $row); 
            } 
            $result->close(); 
        } 
    }while($db->next_result()); 

$db->close();
print_r($rows);
//Procedure
……
select * from T1 where ……
select * from T2 where ……
……

相关文章

  • 几种有用的变型 PHP中循环语句的用法介绍

    几种有用的变型 PHP中循环语句的用法介绍

    for语句可以说是PHP(同时也是多种语言)的循环控制部份最基本的一个语句了,for语句的执行规律和基础用法在这里就不多说,可以参见PHP手册for语句部分
    2012-01-01
  • PHP函数nl2br()与自定义函数nl2p()换行用法分析

    PHP函数nl2br()与自定义函数nl2p()换行用法分析

    这篇文章主要介绍了PHP函数nl2br()与自定义函数nl2p()换行用法,结合实例形式分析PHP函数nl2br实现换行功能的优缺点及自定义函数nl2p换行功能的使用技巧,需要的朋友可以参考下
    2016-04-04
  • PHP7创建COOKIE和销毁COOKIE的实例方法

    PHP7创建COOKIE和销毁COOKIE的实例方法

    在本篇文章里小编给大家整理的是关于PHP7创建COOKIE和销毁COOKIE的实例方法,有需要的朋友们可以参考下。
    2020-02-02
  • php程序之die调试法 快速解决错误

    php程序之die调试法 快速解决错误

    经常看到有初入PHP道朋友对于php程序出现问题素手无策的情况
    2009-09-09
  • 浅谈PHP中JSON数据操作

    浅谈PHP中JSON数据操作

    本文的知识点:1、JSON数据格式介绍,2、对数据编码成JSON格式,3、对JSON数据进行解码,并操作,有需要的小伙伴可以参考下。
    2015-07-07
  • php使用exec shell命令注入的方法讲解

    php使用exec shell命令注入的方法讲解

    exec()是用于执行shell命令的函数,下面说的就是如何使用他用于shell注入的方法讲解
    2013-11-11
  • php代码出现错误分析详解

    php代码出现错误分析详解

    由于最近总是接触到php,经常会出现一些错误,特把php的常见的错误代码收集了下,希望对大家有帮助
    2008-06-06
  • php 判断字符串中是否包含html标签

    php 判断字符串中是否包含html标签

    本篇文章主要是对使用php判断字符串中是否包含html标签的实例代码进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-02-02
  • php封装的数据库函数与用法示例【参考thinkPHP】

    php封装的数据库函数与用法示例【参考thinkPHP】

    这篇文章主要介绍了php封装的数据库函数与用法,基于thinkPHP中数据库操作相关代码整理简化而来,包括针对数据库的设置、连接、查询及日志操作等功能,简单实用,需要的朋友可以参考下
    2016-11-11
  • 提高php运行速度的一些小技巧分享

    提高php运行速度的一些小技巧分享

    使用PHP的最大1个优势就是速度快。一般情况下,PHP总是具有足够的速度支持Web内容动态生成,许多时候甚至无法找出比它更快的方法。然而,当面对庞大的访问量、高负荷的应用、有限的带宽,以及其他各种带来性能瓶颈的因素时,就需要考虑怎样提高PHP的性能了
    2012-07-07

最新评论

?


http://www.vxiaotou.com