집 >데이터 베이스 >MySQL 튜토리얼 >MySQL 쿼리 결과를 PHP에서 JSON으로 효율적으로 인코딩하려면 어떻게 해야 합니까?
PHP에서는 json_encode() 함수를 사용하여 PHP 데이터를 JSON 형식으로 변환합니다. JSON은 널리 지원되는 데이터 형식이므로 웹 애플리케이션이나 API로 데이터를 보낼 때 유용할 수 있습니다.
그런데 MySQL 쿼리 결과에 json_encode()를 어떻게 사용합니까? 결과의 각 행을 반복해야 합니까, 아니면 전체 결과 객체에 적용할 수 있습니까?
<?php $mysqli = new mysqli("host", "username", "password", "database"); $result = $mysqli->query("SELECT * FROM table"); $rows = array(); while ($row = $result->fetch_assoc()) { $rows[] = $row; } $json_data = json_encode($rows); echo $json_data; ?>
이 예에서는 먼저 연결합니다. mysqli 클래스를 사용하여 MySQL 데이터베이스에 연결합니다. 그런 다음 데이터베이스에 대한 쿼리를 실행하고 결과 개체($result)가 $result 변수에 저장됩니다.
fetch_assoc() 메서드를 사용하여 결과 행을 연관 배열($row)로 가져옵니다. . 그런 다음 각 연관 배열($row)을 $rows 배열에 추가합니다.
마지막으로 $rows 배열에 json_encode()를 사용하여 JSON 형식으로 변환합니다. json_data 문자열은 적절하다고 판단되는 방식으로 인쇄하거나 사용할 수 있습니다.
PHP 버전 5.3 이상에서는 위 코드를 다음과 같이 단순화하는 mysqli_fetch_all()을 지원합니다.
<?php $mysqli = new mysqli("host", "username", "password", "database"); $result = $mysqli->query("SELECT * FROM table"); $rows = $result->fetch_all(MYSQLI_ASSOC); // get associative arrays $json_data = json_encode($rows); echo $json_data; ?>
mysqli_fetch_all()을 사용하면 행을 다음과 같이 만들 수 있습니다. 한 번에 검색하여 루프를 절약하고 위와 동일한 결과를 얻었습니다.
위 내용은 MySQL 쿼리 결과를 PHP에서 JSON으로 효율적으로 인코딩하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!