> 백엔드 개발 > PHP 문제 > 쿼리 결과를 PHP에서 배열로 변환하는 방법(3가지 방법)

쿼리 결과를 PHP에서 배열로 변환하는 방법(3가지 방법)

PHPz
풀어 주다: 2023-04-04 21:32:02
원래의
1129명이 탐색했습니다.

PHP에서는 쿼리 결과가 개체나 배열 등 다양한 형식으로 반환되는 경우도 있습니다. 따라서 쿼리 결과를 우리의 요구에 더 부합하도록 쿼리 결과를 배열로 변환하는 몇 가지 방법이 있습니다.

  1. fetch_assoc() 메서드

fetch_assoc() 메서드는 연관 배열을 반환합니다. 여기서 키 이름은 데이터베이스의 필드 이름이고 키 값은 레코드의 해당 값입니다. fetch_assoc() 메서드는 쿼리 결과에서 데이터 행을 반환합니다. 이 메서드를 한 번 호출하면 하나의 행만 반환할 수 있습니다. 다른 행을 읽으려면 이 메서드를 다시 호출해야 합니다.

샘플 코드는 다음과 같습니다.

// 假设 $conn 是 MySQL 数据库连接对象
$sql = "SELECT id, name, age FROM users";
$result = $conn->query($sql);

// fetch_assoc 方法返回一个关联数组
while ($row = $result->fetch_assoc()) {
    echo $row['id'] , $row['name'] , $row['age'];
}
로그인 후 복사
  1. fetch_array() 메소드

fetch_array() 메소드는 숫자 인덱스와 연관 인덱스를 모두 포함하는 배열을 반환하며 이는 연관 배열과 인덱스 배열의 조합과 유사합니다. 숫자 인덱스는 쿼리 결과의 열 인덱스에 해당하고, 연결된 인덱스는 데이터베이스의 필드 이름에 해당합니다. 이 메서드는 반환된 배열이 다르다는 점을 제외하면 fetch_assoc() 메서드와 유사합니다.

샘플 코드는 다음과 같습니다.

// 假设 $conn 是 MySQL 数据库连接对象
$sql = "SELECT id, name, age FROM users";
$result=$conn->query($sql);

// fetch_array 方法返回一个包含关联和数字索引的数组
while ($row = $result->fetch_array()) {
    echo $row['id'] , $row['name'] , $row['age'];
}
로그인 후 복사
  1. fetch_all() 메소드

fetch_all() 메소드는 전체 결과 세트를 반환합니다. 이 메소드는 mysqli 확장 버전 5.3.0 이상에서 사용해야 하며 다음 항목만 지원합니다. MySQL 확장 드라이버 사용. 반환된 결과는 2차원 배열이고, 각 하위 배열은 데이터 행이며, 하위 배열의 요소는 레코드 행의 각 필드에 해당합니다. 이 방법을 사용하면 코드를 단순화할 수 있습니다.

샘플 코드는 다음과 같습니다.

// 假设 $conn 是 MySQL 数据库连接对象
$sql = "SELECT id, name, age FROM users";
$result = $conn->query($sql);

// fetch_all 方法返回一个二维数组
$data = $result->fetch_all();
foreach ($data as $row) {
    echo $row[0] , $row[1], $row[2];
}
로그인 후 복사

Summary

fetch_assoc() 메서드를 사용하여 필드 이름을 키 이름으로 사용하는 연관 배열을 가져오고, fetch_array() 메서드를 사용하여 두 숫자 인덱스를 모두 포함하는 배열을 반환합니다. 및 연관 인덱스, 그리고 fetch_all() 메소드는 전체 결과 세트의 2차원 배열을 직접 반환할 수 있습니다. 상황에 따라 쿼리 결과 배열을 얻는 방법을 다양하게 선택하면 데이터를 보다 편리하게 조작하는 데 도움이 될 수 있습니다.

위 내용은 쿼리 결과를 PHP에서 배열로 변환하는 방법(3가지 방법)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿