PHP를 사용하여 여러 MySQL 쿼리를 하나로 실행
문제:
두 개의 별도 MySQL 쿼리를 실행하고 처리해야 합니다. 그 결과는 PHP에서 독립적으로 나타납니다. 쿼리는 다음과 같습니다.
SELECT SQL_CALC_FOUND_ROWS Id, Name FROM my_table WHERE Name LIKE '%prashant%' LIMIT 0, 10; SELECT FOUND_ROWS();
답변:
PHP의 표준 mysql_ 확장을 사용하면 여러 쿼리를 단일 트랜잭션으로 실행할 수 없습니다. 그러나 다음 단계에 따라 원하는 결과를 얻을 수 있습니다.
- 첫 번째 쿼리 실행:
$query1 = "SELECT SQL_CALC_FOUND_ROWS Id, Name FROM my_table WHERE Name LIKE '%prashant%' LIMIT 0, 10;"; $result1 = mysql_query($query1);
- 두 번째 실행 쿼리:
$query2 = "SELECT FOUND_ROWS();"; $result2 = mysql_query($query2);
- 첫 번째 쿼리 결과 가져오기:
$rows1 = mysql_fetch_all($result1, MYSQL_ASSOC);
- 두 번째 결과 가져오기 쿼리:
$totalRows = mysql_fetch_row($result2)[0];
다음 단계에 따라 두 쿼리를 독립적으로 실행하고 결과를 별도로 처리할 수 있습니다. 이 접근 방식은 단일 트랜잭션으로 실행하는 것만큼 효율적이지는 않지만 mysql_ 확장을 사용하여 원하는 결과를 얻을 수 있는 유일한 방법입니다.
대체 솔루션(사용되지 않음):
업데이트: 이전에는 mysql_connect()를 사용하여 하나의 명령문에서 여러 쿼리를 실행하는 것이 가능하다고 생각되었습니다. 플래그와 함께 기능합니다. 그러나 이 방법은 더 이상 사용되지 않으므로 사용해서는 안 됩니다.
최신 솔루션:
최신 PHP 애플리케이션의 경우 PDO(PHP 데이터 Objects) 데이터베이스 상호 작용을 위한 확장입니다. PDO는 SQL 쿼리를 실행하고 결과를 검색하는 보다 객체 지향적이고 일관된 방법을 제공합니다. PDO를 사용하면 다음과 같이 두 가지 쿼리를 실행할 수 있습니다.
$pdo = new PDO('mysql:host=localhost;dbname=your_database', 'username', 'password'); $stmt1 = $pdo->prepare($query1); $stmt2 = $pdo->prepare($query2); $stmt1->execute(); $rows1 = $stmt1->fetchAll(PDO::FETCH_ASSOC); $stmt2->execute(); $totalRows = $stmt2->fetchColumn();
이 솔루션은 이전 mysql_ 확장보다 더 효율적이고 사용하기 쉽습니다.
위 내용은 PHP에서 여러 MySQL 쿼리를 독립적으로 실행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

TomakePhPapplicationSfaster, followthesesteps : 1) useopCodeCaching likeOpcachetOrpectipiledScriptBecode.2) MinimizedAtabaseQueriesByUsingQueryCachingandEfficientIndexing.3) leveragephp7 assistorBetterCodeeficiession.4) 구현 전략적 지시

toImprovePhPapplicationSpeed, followthesesteps : 1) enableOpCodeCachingWithApcuTeCeScripteXecutionTime.2) 구현 구현

의존성 주입 (DI)은 명시 적으로 전이적 종속성에 의해 PHP 코드의 테스트 가능성을 크게 향상시킵니다. 1) DI 디퍼 커플 링 클래스 및 특정 구현은 테스트 및 유지 보수를보다 유연하게 만듭니다. 2) 세 가지 유형 중에서, 생성자는 상태를 일관성있게 유지하기 위해 명시 적 표현 의존성을 주입합니다. 3) DI 컨테이너를 사용하여 복잡한 종속성을 관리하여 코드 품질 및 개발 효율성을 향상시킵니다.

DatabaseQuesyOptimizationInphPinVolvesVesstoigiestoInsperferferferferformance.1) SelectOnlyNecessaryColumnstoredAtatatransfer.2) useinDexingTeSpeedUpdatarretieval.3) ubstractOrerEresultSoffRequeries.4) UtilizePreDstatements Offeffi

phpisusedforendingemailsduetoitsbuitsbuitsbuit-inmail () functionandsupportivelibraries lifephpmailerandswiftmailer.1) usethemail () functionforbasicemails, butithaslimitations.2) EmployPhpmailerforAdvancedFeatirehtMailsAndAtachments.3))

PHP 성능 병목 현상은 다음 단계를 통해 해결할 수 있습니다. 1) 성능 분석을 위해 Xdebug 또는 Blackfire를 사용하여 문제를 찾으십시오. 2) 데이터베이스 쿼리 최적화 및 APCU와 같은 캐시 사용; 3) Array_Filter와 같은 효율적인 기능을 사용하여 배열 작업을 최적화합니다. 4) 바이트 코드 캐시에 대한 OpCache 구성; 5) HTTP 요청을 줄이고 사진 최적화와 같은 프론트 엔드 최적화; 6) 지속적으로 모니터링하고 성능을 최적화합니다. 이러한 방법을 통해 PHP 응용 프로그램의 성능을 크게 향상시킬 수 있습니다.

종속성 주사 (di) inphpisadesignpattern thatmanages 및 enpleducesclassdelencies, 향상 codemodularity, trestability 및 maintainability .itallowspassingDepporsingDikedAbaseConnectionStoclassesAssparameters, 촉진 이용성.

cachingimprovesphpperferferfermanceStoringResultsOfcomputationSorqueriesforquickRetrieval, retingServerloadandenhancancing responsetimestimes : 1) opcodecaching, opcodecaching, whitescompiledphps scriptsinmorytoskipcompileation; 2) dataCachingUsingmemmc


핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

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

Dreamweaver Mac版
시각적 웹 개발 도구

맨티스BT
Mantis는 제품 결함 추적을 돕기 위해 설계된 배포하기 쉬운 웹 기반 결함 추적 도구입니다. PHP, MySQL 및 웹 서버가 필요합니다. 데모 및 호스팅 서비스를 확인해 보세요.

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

SublimeText3 영어 버전
권장 사항: Win 버전, 코드 프롬프트 지원!