PDO: 열 값별로 연관 배열 그룹화
특정 열 값별로 데이터를 그룹화하면 데이터 세트를 구성하고 조작하는 데 유용할 수 있습니다. 이 질문은 PDO의 fetchAll 메소드를 사용하여 이를 달성하는 방법을 탐색합니다.
제공된 예는 이름, 나이, 성별, 직위와 같은 열이 있는 직원 데이터세트를 보여줍니다. 목표는 이름 열로 그룹화된 연관 배열을 얻어 다음과 같은 배열 구조를 얻는 것입니다.
[ 'Antony' => ['age' => 34, 'sex' => 'M', 'position' => 'programmer'], 'Sally' => ['age' => 30, 'sex' => 'F', 'position' => 'manager'], 'Matthew' => ['age' => 28, 'sex' => 'M', 'position' => 'designer'], ]
PDO::FETCH_GROUP|PDO::FETCH_ASSOC를 사용하는 초기 접근 방식에서는 원치 않는 중첩 수준이 발생합니다. 이 문제를 해결하려면 PDO::FETCH_GROUP|PDO::FETCH_ASSOC|PDO::FETCH_FUNC와 함께 콜백 함수를 사용하는 것이 좋습니다. 그러나 배열 대신 개별 요소를 수신하는 콜백 함수에 문제가 발생합니다.
이 문제에 대한 해결책은 PDO::FETCH_GROUP|PDO::FETCH_UNIQUE를 사용하는 것입니다. 이 접근 방식은 첫 번째 열을 배열 키로 지정하고 나머지 열을 값으로 설정하여 불필요한 중첩이나 배열 조작 없이 원하는 그룹화된 연관 배열을 생성합니다.
위 내용은 PDO를 사용하여 연관 배열을 열 값으로 그룹화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!