比如
$db->query("SET NAMES UTF8");   
if($db->real_query("call sp_test()")){   
    do{   
        echo 'bp';
        if($result = $db->store_result()){   
            while ($row = $result->fetch_assoc()){   
                array_push($rows, $row);   
            }   
            $result->close();   
        }   
    }while($db->next_result());   
}   
$db->close(); 你会发现假设你返回1个结果集,会打出2个bp,2个结果集就会echo出3个bp,但如果不写存储,直接写语句,就正常,不会多出一个,求大神指点迷津!

解决方案 »

  1.   

    这不是很正常吗?不然你要 if($result = $db->store_result()){ 干什么?
      

  2.   


    您好,可是直接写语句在php里不会多出一个,比如select 1;select 2;他就打出2个bp,这是为什么呢,存储过程里也写以上2句就会打出3个
      

  3.   

    php 的数据库函数不支持形如 select 1;select 2; 这样的查询,所以不能作为参照系
       do{   
            if($result = $db->store_result()){   
            }   
        }while($db->next_result());   
    这样的代码结构是读取存储过程结果集必须的,如果你认为是 bug,可以去 php bug 网站去投诉。
    不过在没有改正之前,你还是必须这么做
      

  4.   

    因为你echo写在了 if($result = $db->store_result()){ 的前面,而有没有结果是要看 if($result = $db->store_result()){ 的判断结果才知道,所以肯定有2个结果的时候, if要判断3次,也就是你说的3次bp其实简单说,你的困惑在于
    $i = 1;
    $max = 2;
    while(true) {
    echo "A"; // 这里肯定会输出3个A
    if($i > $max) {
        break;
    }
    $i++;
    }
      

  5.   


    大侠,不好意思,我还想问下,$result = $db->store_result(),这句话到底是什么意思,这是赋值运算,怎么就能返回bool值呢?
      

  6.   

    $db->store_result() 返回一个查询结果资源
    当没有了的时候,返回的就是空了(null)
      

  7.   


    那$result =null  这个返回的是false吗?
      

  8.   

    还真是false,一个赋值表达式都能返回false,php真神奇
      

  9.   

    是我理解错了,运来if里面判断的仅仅是$result的值!!