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

 更新时间:2013年07月03日 11:46:26   作者:  
本篇文章是对php调用MySQL存储过程的方法进行了集合与汇总,需要的朋友参考下
类型一:调用带输入、输出类型参数的方法
复制代码 代码如下:

$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获取文件大小的方法

    这篇文章主要介绍了php获取文件大小的方法,需要的朋友可以参考下
    2014-02-02
  • PHP数组在底层的实现原理详解

    PHP数组在底层的实现原理详解

    这篇文章讲给大家详细介绍一下PHP数组在底层的实现原理,PHP数组在底层的实现原理可以分为两种类型:基于哈希表的实现和基于有序列表的实现,文中通过代码示例介绍的非常详细,具有一定的参考价值,需要的朋友可以参考下
    2023-11-11
  • PHP插件PHPMailer发送邮件功能

    PHP插件PHPMailer发送邮件功能

    这篇文章主要为大家详细介绍了PHP发送邮件功能,一个PHPMailer插件轻松实现邮件发送功能,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-02-02
  • PHP里的中文变量说明

    PHP里的中文变量说明

    一般在我们概念里变量都应该是有字母,数字,下划线组成,可在PHP下中文也可以作为变量的一部分,今天就要讲讲PHP的变量
    2011-07-07
  • php magic_quotes_gpc的一点认识与分析

    php magic_quotes_gpc的一点认识与分析

    最近一直在做一个文章发布系统,做了改,改了做,一直到现在还没竣工.... 为了达到更好的兼容性,其中的程序涉及到了magic_quotes_gpc,看了下手册,又找了些资料,分析了下,分享给大家。
    2008-08-08
  • php中将地址生成迅雷快车旋风链接的代码[测试通过]

    php中将地址生成迅雷快车旋风链接的代码[测试通过]

    php中将地址生成迅雷快车旋风链接的代码,非常不错,将下面的代码保存为cs.php运行即可。
    2011-04-04
  • php 8小时时间差的解决方法小结

    php 8小时时间差的解决方法小结

    前几天发现一个问题 date("Y-m-d G:i T",time()) 取出来的时间和本地时间老差8个小时,可我的系统明明是中国标准时(GMT+8),最后终于找到了问题所在。
    2009-12-12
  • php中在PDO中使用事务(Transaction)

    php中在PDO中使用事务(Transaction)

    事务 (Transaction) 是操作数据库中很重要的一个功能, 它可以让你预定一条, 或者一系列 SQL 语句, 然后一起执行
    2011-05-05
  • Linux平台PHP5.4设置FPM线程数量的方法

    Linux平台PHP5.4设置FPM线程数量的方法

    这篇文章主要介绍了Linux平台PHP5.4设置FPM线程数量的方法,较为详细的分析了Linux平台php5.4设置FPM的相关参数、功能及使用技巧,需要的朋友可以参考下
    2016-11-11
  • 支持数组的ADDSLASHES的php函数

    支持数组的ADDSLASHES的php函数

    支持数组的ADDSLASHES
    2010-02-02

最新评论