mysql查询的1个存储过程,显示2个查询结果,如何在PHP里把2个结果显示出来

php中文网
发布: 2016-06-13 13:29:41
原创
1232人浏览过
mysql查询的1个存储过程,显示2个查询结果,怎么在PHP里把2个结果显示出来
mysql查询的1个存储过程,显示2个查询结果,怎么在PHP里把2个结果显示出来
------------------------------
mysql存储过程:
-------------------------------
begin
  declare strSQL varchar(3000);
  declare beginnum int;
  declare strCount_s varchar(2000);  
  /*判断页数,如果是空或者0或者null默认第一页*/
  if(PageIndex is null or PageIndex = '' or PageIndex = 0)
  then
set PageIndex = 1;
  end if;
/*判断每页显示数,如果是空或者0或者null默认第一条*/
  if (SplitCount=0 or SplitCount='' or SplitCount is null)
then
set SplitCount = 1;
end if; 
  /*根据条件,查询所有数据集*/
  set @beginnum = (PageIndex -1) * SplitCount; 
  set @strSQL = concat('select ', numtype, ' from ', tablename, ' where ', wheretype,' ' , OrderBy, ' limit ',@beginnum, ',', SplitCount);  
   
  PREPARE stmt from @strSQL;
  execute stmt;  
  DEALLOCATE PREPARE stmt;
  /*根据条件,查询总数据数量*/
  set @strCount_s=concat('select count(1) as countnum from ', tablename,' where ', wheretype);
  prepare select_rowscount from @strCount_s;
  execute select_rowscount;
  DEALLOCATE PREPARE select_rowscount;

end

MYSQL结果1: DEALLOCATE PREPARE stmt; 输出的所有查询数据
MYSQL结果2: DEALLOCATE PREPARE select_rowscount; 输出查询总数量
----------------------------------------

PHP存储过程类

----------------------------------------
/**
* 存储过程操作
*
* @param $produceAndParams 存储过程名称及参数
* 格式为ProduceName(para1, para2.....),
* 如果参数是字符请加单引号
* @return $resultnum 返回操作成功影响的行数
* @throws Exception 存储过程异常
*/
public static function RunProduce($produceAndParams)
{
global $_config;
if (!mysql_query("SET NAMES ".$_config['coding'], self::$_wdbConn)) {
throw new Exception("设置字符集".$_config['coding']."失败:".mysql_error());
}
if(!mysql_query('call '.$produceAndParams.';', self::$_wdbConn)) {
throw new Exception("调用存储过程失败:".mysql_error());
}
$resultNum = mysql_affected_rows(self::$_wdbConn);
return $resultNum;
}

----------------------------------

怎么在PHP里写,能把存储过程查询的2个结果显示出来



------解决方案--------------------
我搜集的资料,你可以参考一下:


PHP code
php调用MySQL存储过程方法集合

类型一:调用带输入、输出类型参数的方法
view plainprint?
$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; //输出来自存储过程中输出的变量  

类型二:调用带多个输出类型和多个输入类型参数的方法
view plainprint?
$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  

类型三:调用带返回结果集的方法
view plainprint?
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来实现~~~~~)
view plainprint?
//PHP  
$rows = array ();    
$db = new mysqli($server,$user,$psd,$dbname);    
if (mysqli_connect_errno()){    
    $this-&gt;message('Can not connect to MySQL server');    
}    
$db-&gt;query("SET NAMES UTF8");    
$db-&gt;query("SET @Message");  
if($db-&gt;real_query("call P__Test_GetData2(@Message)")){    
    do{    
        if($result = $db-&gt;store_result()){    
            while ($row = $result-&gt;fetch_assoc()){    
                array_push($rows, $row);    
            }    
            $result-&gt;close();    
        }    
    }while($db-&gt;next_result());    
}    
$db-&gt;close();   
print_r($rows); <div class="clear"></div>
登录后复制
相关标签:
PHP速学教程(入门到精通)
PHP速学教程(入门到精通)

PHP怎么学习?PHP怎么入门?PHP在哪学?PHP怎么学才快?不用担心,这里为大家提供了PHP速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号