이 기사의 예에서는 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)
두 세션에서 얻은 결과가 일치하지 않는 것을 볼 수 있습니다. 기본적으로 서로 다른 세션에 속하는 두 호출이 서로 다른 값을 갖게 되는 것은 확실합니다.
일관성을 위해 다음 호출을 사용할 수 있습니다.
<?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(); ?>
$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 프로그래밍에 종사하는 모든 사람에게 도움이 되기를 바랍니다.