PHP_php에서 저장 프로시저를 호출할 때 반환 값이 일관되지 않는 문제에 대한 솔루션 분석 팁
이 기사의 예에서는 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 프로그래밍에 종사하는 모든 사람에게 도움이 되기를 바랍니다.

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











PHP에서 최종 키워드는 클래스가 상속되고 메소드가 덮어 쓰는 것을 방지하는 데 사용됩니다. 1) 클래스를 최종적으로 표시 할 때는 수업을 상속받을 수 없습니다. 2) 메소드를 최종으로 표시 할 때는 메소드를 서브 클래스로 다시 작성할 수 없습니다. 최종 키워드를 사용하면 코드의 안정성과 보안이 보장됩니다.

Root로 MySQL에 로그인 할 수없는 주된 이유는 권한 문제, 구성 파일 오류, 암호 일관성이 없음, 소켓 파일 문제 또는 방화벽 차단입니다. 솔루션에는 다음이 포함됩니다. 구성 파일의 BAND-ADDRESS 매개 변수가 올바르게 구성되어 있는지 확인하십시오. 루트 사용자 권한이 수정 또는 삭제되어 재설정되었는지 확인하십시오. 케이스 및 특수 문자를 포함하여 비밀번호가 정확한지 확인하십시오. 소켓 파일 권한 설정 및 경로를 확인하십시오. 방화벽이 MySQL 서버에 연결되는지 확인하십시오.

Vue의 내보내기 기본값은 다음과 같이 밝혀집니다. 기본 내보내기, 이름을 지정하지 않고 전체 모듈을 한 번에 가져옵니다. 컴포넌트는 컴파일 시간에 모듈로 변환되며 사용 가능한 모듈은 빌드 도구를 통해 포장됩니다. 상수 또는 함수와 같은 다른 컨텐츠와 같은 지명 된 수출 및 내보내기와 결합 할 수 있습니다. 자주 묻는 질문에는 원형 종속성, 경로 오류 및 구축 오류가 포함되며, 코드 및 가져 오기 문을주의 깊게 조사해야합니다. 모범 사례에는 코드 세분화, 가독성 및 구성 요소 재사용이 포함됩니다.

MySQL 설치 오류에 대한 솔루션은 다음과 같습니다. 1. MySQL 종속성 라이브러리 요구 사항이 충족되도록 시스템 환경을주의 깊게 확인하십시오. 다른 운영 체제 및 버전 요구 사항이 다릅니다. 2. 오류 메시지를주의 깊게 읽고 프롬프트 (예 : 라이브러리 파일 누락 또는 부족한 권한)에 따라 종속성 설치 또는 Sudo 명령 사용과 같은 해당 조치를 취합니다. 3. 필요한 경우 소스 코드를 설치하고 컴파일 로그를주의 깊게 확인하십시오. 그러나 일정량의 Linux 지식과 경험이 필요합니다. 궁극적으로 문제를 해결하는 핵심은 시스템 환경 및 오류 정보를 신중하게 확인하고 공식 문서를 참조하는 것입니다.

서버에서 데이터를 얻기 위해 ajax를 사용하는 시점에 달린 부트 스트랩 코드에 대한 솔루션 : 1. 서버 측 코드 (예 : UTF-8)의 올바른 문자 인코딩을 설정하십시오. 2. AJAX 요청에서 요청 헤더를 설정하고 허용 된 문자 인코딩 (수락-차 세트)을 지정하십시오. 3. 부트 스트랩 테이블의 "Unescape"변환기를 사용하여 탈출 한 HTML 엔티티를 원래 문자로 해독하십시오.

다음 단계는 Navicat이 데이터베이스에 연결할 수없는 문제를 해결하는 데 사용될 수 있습니다. 서버 연결을 확인하고 서버가 실행되고 주소 및 포트가 올바르게 작동하는지 확인하고 방화벽에서 연결을 허용합니다. 로그인 정보를 확인하고 사용자 이름, 암호 및 권한이 올바른지 확인하십시오. 네트워크 연결을 확인하고 라우터 또는 방화벽 고장과 같은 네트워크 문제를 해결하십시오. 일부 서버에서 지원하지 않을 수있는 SSL 연결을 비활성화하십시오. Navicat 버전이 대상 데이터베이스와 호환되는지 확인하려면 데이터베이스 버전을 확인하십시오. 연결 시간 초과를 조정하고 원격 또는 느린 연결의 경우 연결 시간 초과를 늘리십시오. 다른 해결 방법, 위의 단계가 작동하지 않으면 소프트웨어를 다시 시작하거나 다른 연결 드라이버를 사용하거나 데이터베이스 관리자 또는 공식 Navicat 지원을 컨설팅 할 수 있습니다.

PHP의 미래는 새로운 기술 트렌드에 적응하고 혁신적인 기능을 도입함으로써 달성 될 것입니다. 1) 클라우드 컴퓨팅, 컨테이너화 및 마이크로 서비스 아키텍처에 적응, Docker 및 Kubernetes 지원; 2) 성능 및 데이터 처리 효율을 향상시키기 위해 JIT 컴파일러 및 열거 유형을 도입합니다. 3) 지속적으로 성능을 최적화하고 모범 사례를 홍보합니다.

MySQL 설치 실패의 주된 이유는 다음과 같습니다. 1. 권한 문제, 관리자로 실행하거나 Sudo 명령을 사용해야합니다. 2. 종속성이 누락되었으며 관련 개발 패키지를 설치해야합니다. 3. 포트 충돌, 포트 3306을 차지하는 프로그램을 닫거나 구성 파일을 수정해야합니다. 4. 설치 패키지가 손상되어 무결성을 다운로드하여 확인해야합니다. 5. 환경 변수가 잘못 구성되었으며 운영 체제에 따라 환경 변수를 올바르게 구성해야합니다. 이러한 문제를 해결하고 각 단계를 신중하게 확인하여 MySQL을 성공적으로 설치하십시오.
