문제:
PHP 스크립트에서 특정 코드 섹션 전에 실행이 중지됩니다. 특히 파일(file4.txt)이 생성되어야 하는 코드 섹션입니다. 이 동작은 스크립트를 디버깅하는 동안 발생합니다.
가능한 원인:
"알 수 없는 테이블 상태: TABLE_TYPE" 오류 메시지는 데이터베이스 쿼리에 문제가 있음을 나타냅니다. 이는 데이터베이스 연결이 제대로 설정되지 않았거나 참조된 테이블이 존재하지 않거나 액세스할 수 없는 경우 발생할 수 있습니다.
해결책:
이 문제를 해결하려면, 다음 단계를 고려하세요.
1. 분할하고 정복하세요:
대본을 더 작은 섹션으로 나누어 문제가 있는 부분을 식별하세요.
2. 파일 조작 유틸리티:
파일 작업을 처리하는 별도의 함수(예: file_put)를 생성하여 수정 및 디버깅을 더 쉽게 할 수 있습니다.
3. 향상된 데이터베이스 관리:
MySQL 관련 작업을 별도의 클래스로 이동하여 복잡성을 추상화합니다. 이를 통해 가독성과 오류 처리 능력이 향상될 수 있습니다.
4. 포괄적인 오류 처리:
오류 메시지가 명확하게 캡처 및 표시되어 문제의 원인에 대한 통찰력을 제공하는지 확인하세요.
5. 단순화된 데이터베이스 쿼리:
'로그' 테이블에서 데이터를 가져오는 복잡한 쿼리를 더 간단하고 간단한 명령문으로 다시 작성합니다.
자세한 데모:
다음 코드는 원본 스크립트의 개선된 버전입니다.
// MySQL Exception class class MySqlException extends RuntimeException {} // MySQL Database class class MySql { ... } // MySql Result Set - Array Based class class MySqlResult implements Iterator, Countable { ... } // File manipulation function function file_put($number, $data) { ... } // Simplified checkin function function checkin(MySql $DB, $TechID, $ClientID, $SiteID) { $result1 = $DB->query("SELECT COUNT(*) FROM Log"); foreach ($result1 as $row1) { $count = $row1['COUNT(*)']; $file3 = "C:/wamp/www/file3.txt"; file_put_contents($file3, "ClientID:$ClientID TechID:$TechID SiteID:$SiteID Count:$count"); } } // Create database object and connect $config = [ ... ]; $db = new MySql($config); // Execute checkin function checkin($db, 1, 2, 3, 4);
위 내용은 file4.txt를 생성하기 전에 PHP 스크립트가 중지되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!