집 >데이터 베이스 >MySQL 튜토리얼 >PHP 7에서 '치명적인 오류: [] 연산자는 문자열에 지원되지 않습니다.' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?
오류 이해: "치명적인 오류: [] 연산자는 문자열에 지원되지 않습니다."
데이터베이스에서 데이터를 수정하려고 하면 "[] 연산자는 문자열에 지원되지 않습니다." 오류가 발생했습니다. 이 오류는 문자열에 짧은 배열 푸시 구문을 사용하려는 시도를 나타냅니다.
근본 원인:
코드를 검토한 결과 하나 이상을 초기화한 것으로 보입니다. 변수($name, $date, $text, $date2)를 문자열로 저장합니다. 이는 문자열 값인 $row[''] 값 할당에서 분명합니다.
해결책:
이 문제를 해결하려면 변경해야 합니다. 할당:
$name = $row['name']; $date = $row['date']; $text = $row['text']; $date2 = $row['date2'];
이렇게 하면 이러한 변수가 문자열이 아닌 문자열로 처리됩니다.
PHP 7 엄격성 이해:
PHP 7에는 빈 인덱스 배열 푸시 구문 사용에 대한 더 엄격한 제어 기능이 있습니다. 이제 배열이 아닌 변수에 사용하려고 하면 오류가 발생합니다.
PHP 7의 유효한 빈 인덱스 배열 푸시 구문의 예:
$previouslyUndeclaredVariableName[] = 'value'; // creates an array and adds an entry $emptyArray = []; // creates an array $emptyArray[] = 'value'; // pushes in an entry
그러나 다음은 치명적인 오류를 발생시킵니다.
$declaredAsString = ''; $declaredAsString[] = 'value'; $declaredAsNumber = 1; $declaredAsNumber[] = 'value'; $declaredAsObject = new stdclass(); $declaredAsObject[] = 'value';
이러한 지침을 따르면 이 오류를 방지하고 데이터베이스 수정이 제대로 작동하는지 확인할 수 있습니다. 코드입니다.
위 내용은 PHP 7에서 '치명적인 오류: [] 연산자는 문자열에 지원되지 않습니다.' 오류가 발생하는 이유는 무엇이며 어떻게 해결할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!