>데이터 베이스 >MySQL 튜토리얼 >MySQL 쿼리 결과를 PHP에서 JSON으로 효율적으로 인코딩하려면 어떻게 해야 합니까?

MySQL 쿼리 결과를 PHP에서 JSON으로 효율적으로 인코딩하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-23 19:23:14530검색

How Can I Efficiently Encode MySQL Query Results as JSON in PHP?

PHP를 사용하여 MySQL 결과를 JSON으로 인코딩

PHP에서는 json_encode() 함수를 사용하여 PHP 데이터를 JSON 형식으로 변환합니다. JSON은 널리 지원되는 데이터 형식이므로 웹 애플리케이션이나 API로 데이터를 보낼 때 유용할 수 있습니다.

그런데 MySQL 쿼리 결과에 json_encode()를 어떻게 사용합니까? 결과의 각 행을 반복해야 합니까, 아니면 전체 결과 객체에 적용할 수 있습니까?

MySQLi에서 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 문자열은 적절하다고 판단되는 방식으로 인쇄하거나 사용할 수 있습니다.

mysqli_fetch_all() 사용

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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.