>  기사  >  백엔드 개발  >  PHP는 쿼리 결과를 2차원 배열로 변환합니다.

PHP는 쿼리 결과를 2차원 배열로 변환합니다.

WBOY
WBOY원래의
2023-05-05 20:23:07488검색

php는 웹 애플리케이션을 개발하는 데 자주 사용되는 인기 있는 프로그래밍 언어입니다. 데이터베이스 쿼리는 PHP에서 일반적으로 사용되는 작업 중 하나이며 쿼리 결과는 배열 형식으로 반환되어야 합니다. 이 문서에서는 쿼리 결과를 2차원 배열로 변환하는 방법을 설명합니다.

1. 쿼리 결과

PHP에서는 mysqli 또는 PDO를 사용하여 쿼리 작업을 위해 데이터베이스에 연결합니다. 다음은 mysqli 쿼리를 사용한 샘플 코드입니다.

$mysqli = new mysqli("localhost", "user", "password", "database");
$sql = "SELECT name, age FROM users";
$result = $mysqli->query($sql);

PDO를 사용한 샘플 코드:

$pdo = new PDO("mysql:host=localhost;dbname=database", "user", "password");
$sql = "SELECT name, age FROM users";
$result = $pdo->query($sql);

mysqli인지 PDO인지에 관계없이 쿼리문을 실행하면 결과 세트 객체가 반환됩니다.

2. 결과를 배열로 변환

쿼리 결과를 배열로 변환하는 방법에는 두 가지가 있습니다. 하나는 mysqli 또는 PDO와 함께 제공되는 fetch 함수를 사용하여 행 단위로 변환하는 것입니다. 전체 결과 세트를 한 번에 배열로 가져옵니다.

  1. fetch() 메서드

fetch 메서드는 결과 집합에서 데이터 행을 꺼내고 포인터를 한 행 아래로 이동하는 데 사용됩니다. fetch() 메소드는 전체 결과 세트를 얻기 위해 루프에서 호출될 수 있습니다. 다음은 샘플 코드입니다.

// mysqli示例代码
$rows = array();
while ($row = $result->fetch_assoc()) {
    $rows[] = $row;
}

// PDO示例代码
$rows = array();
while ($row = $result->fetch(PDO::FETCH_ASSOC)) {
    $rows[] = $row;
}

위 코드는 fetch_assoc() 또는 FETCH_ASSOC를 사용하여 연관 배열을 검색합니다. 또한 fetch_array() 또는 FETCH_BOTH를 사용하여 숫자 및 관련 키가 포함된 배열을 얻을 수도 있습니다. 객체.

  1. fetch_all() 메소드

fetch_all() 메소드는 전체 결과 세트를 한 번에 배열로 가져오는 것입니다. fetch_all()은 PDO의 함수입니다. mysqli에서는 결과 집합 개체를 얻으려면 get_result()를 사용해야 합니다. 다음은 샘플 코드입니다.

// mysqli示例代码
$rows = $result->get_result()->fetch_all(MYSQLI_ASSOC);

// PDO示例代码
$rows = $result->fetch_all(PDO::FETCH_ASSOC);

위 코드는 결과 세트를 한번에 꺼내어 결과 세트에 있는 모든 데이터를 연관 배열 형태로 2차원 배열로 저장합니다.

3. 요약

위에 소개된 두 가지 방법은 각각 장점과 단점이 있습니다. fetch() 방법을 사용하면 결과를 한 줄씩 처리할 수 있어 더 유연하지만 각 줄을 처리하는 데 많은 코드가 필요합니다. 데이터. fetch_all() 메소드는 전체 결과를 한 번에 가져올 수 있습니다. 코드는 간단하지만 데이터 양이 너무 많으면 메모리를 너무 많이 차지할 수 있습니다.

실제 개발에서는 실제 상황에 따라 적절한 방법을 선택할 수 있습니다. 쿼리 결과 집합이 작다면 fetch() 메서드를 사용할 수 있고, 그렇지 않으면 fetch_all() 메서드를 사용하는 것이 좋습니다.

위 내용은 PHP는 쿼리 결과를 2차원 배열로 변환합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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