たった 1 つのデータベース パスで PHP/MySQL の階層カテゴリ データを取得する方法

Linda Hamilton
リリース: 2024-10-23 17:46:01
オリジナル
539 人が閲覧しました

How to Retrieve Hierarchical Category Data in PHP/MySQL with Just One Database Pass?

PHP/MySQL のカテゴリ階層

PHP/MySQL では、隣接リストモデル。この階層データを効果的に取得するには、データベース パスを 1 つだけ必要とするアプローチを採用できます。

ワンパス データ取得アルゴリズム

$refs 配列を作成してみましょう。 $list 配列。提供された回答で示されているものに似ています。

<code class="php">$refs = [];
$list = [];

$sql = "SELECT category_id, parent_id, name FROM categories ORDER BY name";

$result = $pdo->query($sql);

foreach ($result as $row) {
    $ref = &$refs[$row['category_id']];

    $ref['parent_id'] = $row['parent_id'];
    $ref['name'] = $row['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>';

    foreach ($array as $value) {
        $html .= '<li>' . $value['name'];
        if (!empty($value['children'])) {
            $html .= toUL($value['children']);
        }
        $html .= '</li>';
    }

    $html .= '</ul>';

    return $html;
}</code>
ログイン後にコピー

この関数は、データベースから取得した階層データを効率的に表す HTML リストを再帰的に構築します。

以上がたった 1 つのデータベース パスで PHP/MySQL の階層カテゴリ データを取得する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:php
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
著者別の最新記事
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート
私たちについて 免責事項 Sitemap
PHP中国語ウェブサイト:福祉オンライン PHP トレーニング,PHP 学習者の迅速な成長を支援します!