집 >데이터 베이스 >MySQL 튜토리얼 >PHP/MySQL에서 계층적 데이터(범주)를 시각화하는 방법은 무엇입니까?
PHP/MySQL의 카테고리 계층
카테고리와 같은 계층적 데이터를 처리할 때는 이를 구조화된 방식으로 표현하는 것이 중요합니다. 일반적인 접근 방식 중 하나는 각 행이 카테고리를 나타내고 해당 상위 카테고리를 나타내는 필드가 있는 인접 목록 모델을 사용하는 것입니다.
계층 구조 얻기
PHP를 사용하면 MySQL에서 카테고리 데이터를 검색하고 단일 패스로 계층 구조를 구축할 수 있습니다. Nate Weiner의 "One Pass Parent-Child Array Structure"에서 영감을 받은 아래 코드:
<code class="php">$refs = []; $list = []; $sql = "SELECT category_id, parent_id, category_name FROM categories ORDER BY category_name"; foreach ($result as $row) { $ref = &$refs[$row['category_id']]; $ref['parent_id'] = $row['parent_id']; $ref['category_name'] = $row['category_name']; if ($row['parent_id'] == 0) { $list[$row['category_id']] = &$ref; } else { $refs[$row['parent_id']]['children'][$row['category_id']] = &$ref; } }</code>
이 루프는 두 개의 배열을 채웁니다. $refs에는 각 카테고리에 대한 참조가 포함되고 $list에는 최상위 카테고리가 포함됩니다. (상위 없음).
계층 표현 생성
계층의 시각적 표현을 생성하려면 재귀 함수를 사용하여 중첩된 HTML 목록을 생성할 수 있습니다. 다음 코드를 고려해보세요.
<code class="php">function toUL(array $array) { $html = '<ul>' . PHP_EOL; foreach ($array as $value) { $html .= '<li>' . $value['category_name']; if (!empty($value['children'])) { $html .= toUL($value['children']); } $html .= '</li>' . PHP_EOL; } $html .= '</ul>' . PHP_EOL; return $html; }</code>
이 함수는 범주 배열을 입력으로 사용하고 중첩된 HTML 목록을 반복적으로 작성합니다. 그런 다음 결과 HTML을 출력하여 카테고리 계층 구조를 표시할 수 있습니다.
위 내용은 PHP/MySQL에서 계층적 데이터(범주)를 시각화하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!