>  기사  >  백엔드 개발  >  PHP_php에서 저장 프로시저를 호출할 때 반환 값이 일관되지 않는 문제에 대한 솔루션 분석 팁

PHP_php에서 저장 프로시저를 호출할 때 반환 값이 일관되지 않는 문제에 대한 솔루션 분석 팁

WBOY
WBOY원래의
2016-05-16 19:53:421261검색

이 기사의 예에서는 PHP에서 저장 프로시저를 호출할 때 반환 값이 일관되지 않는 문제에 대한 해결 방법을 설명합니다. 참고하실 수 있도록 모든 사람과 공유하세요. 자세한 내용은 다음과 같습니다.

오늘 저장 프로시저의 반환 값에 대해 이야기하던 중 예상치 못한 null 값이 자주 나오는 친구를 만났습니다. 낮에 할 일이 있어서 저녁에 실험을 해서 여기에 넣어두었습니다. 확인해야 할 해당 질문이 있는 학생.

저장 프로시저:

delimiter//
createprocedureusp_s2(outpar1int)
begin
selectinet_ntoa(ip),portfromproxy_listlimit5;
selectcount(*)intopar1fromproxy_list;
END//
delimiter;

세션 1 실행:

mysql>callusp_s2(@a);
+—————+——+
|inet_ntoa(ip)|port|
+—————+——+
|1.34.21.86  |8088|
|1.34.59.50  |8088|
|1.34.69.15  |8088|
|1.34.73.110  |8088|
|1.34.76.218  |8088|
+—————+——+
5rowsinset(0.00sec)
QueryOK,1rowaffected(0.01sec)
mysql>select@a;
+——+
|@a  |
+——+
|4430|
+——+
1rowinset(0.00sec)

세션 2 실행:

mysql>select@a;
+——+
|@a  |
+——+
|NULL|
+——+
1rowinset(0.00sec)

두 세션에서 얻은 결과가 일치하지 않는 것을 볼 수 있습니다. 기본적으로 서로 다른 세션에 속하는 두 호출이 서로 다른 값을 갖게 되는 것은 확실합니다.
일관성을 위해 다음 호출을 사용할 수 있습니다.

<&#63;php
$hostname="127.0.0.1";
$username="wubx";
$password="wubxwubx";
$database="proxydb";
$db=newmysqli($hostname,$username,$password,$database);
if(mysqli_connect_errno()){
    printf("Connect failed: %s\n",mysqli_connect_error());
    exit();
}
$result=$db->multi_query("call usp_s2(@total); select @total;");
if($result){
    do{
    if($r=$db->store_result()){
        if($r->field_count==2){
            while($row=$r->fetch_row()){
                print"ip: $row[0], port: $row[1]\n";
            }
        }else{
            $row =$r->fetch_row();
            print"total: $row[0]\n";
        }
    }
    }while($db->next_result());
}
$db->close();
&#63;>

$phpt_proc_return.php
ip:1.34.21.86,port:8088
ip:1.34.59.50,port:8088
ip:1.34.69.15,포트:8088
IP:1.34.73.110,포트:8088
IP:1.34.76.218,포트:8088
합계:4430

행운을 빕니다.

더 많은 PHP 관련 콘텐츠에 관심이 있는 독자는 이 사이트에서 "MySQL 저장 프로시저 기술 모음", "PHP 데이터 구조 및 알고리즘 튜토리얼과 같은 특별 주제를 확인할 수 있습니다. ", "PHP 연산 및 연산자 사용법 요약", "PHP 네트워크 프로그래밍 기술 요약", "PHP 기본 구문 입문 튜토리얼", "PHP 운영 문서 스킬 요약(워드, 엑셀, 액세스, ppt 포함)", "php 날짜 및 시간 사용 요약", "php 객체지향 프로그래밍 입문 튜토리얼", "php 스트링(문자열) 사용법 요약", "php mysql 데이터베이스 운용 입문 튜토리얼", "php 스트링(string) 사용법 요약 "

이 기사가 PHP 프로그래밍에 종사하는 모든 사람에게 도움이 되기를 바랍니다.

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.