-1

現在、次のようなテーブルがあります。

+-----------+---------------+-------------+-------------+
| category  | OrderID       | Name        | Name2       |
+-----------+---------------+-------------+-------------+
| ABC       | 12345         | Pen         | Black       |
+-----------+---------------+-------------+-------------+
| ABC       | 34545         | Pencil      | White       |   
+-----------+---------------+-------------+-------------+
| ABC       | 34545         | Pen         | Black       |
+-----------+---------------+-------------+-------------+
| DEF       | 12345         | Pencil      | Black       |
+-----------+---------------+-------------+-------------+
| DEF       | 12345         | Pen         | White       |
+-----------+---------------+-------------+-------------+

これをツリー形式にするのが好きです。ref で非常に多くの例を読みました。再帰的ですが、概念を理解していませんでした。誰か助けてくれませんか?

テーブルは巨大になるため (約 20K レコードになる可能性があります)、再帰がパフォーマンスなどに影響を与えるかどうかはわかりません。

クライアントの html ウィジェットの制限により、この形式で実行する必要があります。

Array
(
[0] => Array
    (
        [category] => ABC
        [children] => Array
            (
            [0] => Array(
                [OrderID] => 12345
                [children] => Array
                    (
                        [Name] => Pen
                        [Name2] => Black

                    )
            )
            [1] => Array(
                [OrderID] => 34545
                [children] => Array
                (
                    [0] => Array(
                        [Name] => Pencil
                        [Name2] => White
                    )
                    [1] => Array(
                        [Name] => Pen
                        [Name2] => White
                    )
                )
            )

    )

[1] => Array
    (
        [category] => DEF
        [children] => Array
            (
                [OrderID] => 12345
                [children] => Array
                (
                    [0] => Array(
                        [Name] => Pencil
                        [Name2] => Black
                    )
                    [1] => Array(
                        [Name] => Pen
                        [Name2] => White
                    )
                )
            )
    )
4

1 に答える 1

0

グループ化する必要がある値を配列コンテンツに入れることは、多くの場合、良い考えではありません。値をルックアップ キーとして使用できず、グループ化がより困難で非効率になるためです。

$ori=json_decode(<<<JSON
[{"category":"ABC","orderID":"12345","Name":"Pen","Name2":"Black"},
{"category":"ABC","orderID":"34545","Name":"Pencil","Name2":"White"},
{"category":"ABC","orderID":"34545","Name":"Pen","Name2":"Black"},
{"category":"DEF","orderID":"12345","Name":"Pencil","Name2":"Black"},
{"category":"DEF","orderID":"12345","Name":"Pen","Name2":"White"}]
JSON
,true);
$result=array();
while($row=array_shift($ori))//Pretend that we're fetching record from DB
{
    $result[$row["category"]][$row["orderID"]][]=array("Name"=>$row["Name"],"Name2"=>$row["Name2"]);
}
print_r($result);

グループ化された値 (categoryおよびorderID) を配列キーとして使用することで、検索とグループ化がより効率的になります。上記のコードは以下を出力します。

Array
(
    [ABC] => Array
        (
            [12345] => Array
                (
                    [0] => Array
                        (
                            [Name] => Pen
                            [Name2] => Black
                        )

                )

            [34545] => Array
                (
......

それでも同じcount()結果が得られ、特定のカテゴリと順序をより簡単に見つけることができるという利点があります$result[category][order]["Name"]=...

ただし、目的の形式を取得することを主張する場合でも、次を追加できます。

array_walk($result,function(&$v,$k){
    $x=array("category"=>$k,"children"=>array());
    array_walk($v,function($arr,$oid)use(&$x){
        $x["children"][]=array("orderID"=>$oid,"children"=>$arr);
    });
    $v=$x;
});
print_r(array_values($result));

これは以下を出力します:

Array
(
    [0] => Array
        (
            [category] => ABC
            [children] => Array
                (
                    [0] => Array
                        (
                            [orderID] => 12345
                            [children] => Array
                                (
                                    [0] => Array
                                        (
                                            [Name] => Pen
                                            [Name2] => Black
                                        )

                                )

                        )

                    [1] => Array
                        (
                            [orderID] => 34545
......

デモ。匿名関数には PHP>=5.3 が必要です

于 2013-07-23T08:13:11.470 に答える