ホームページ  >  記事  >  バックエンド開発  >  データベースからクエリしたツリー構造データを配列に循環的に代入する方法

データベースからクエリしたツリー構造データを配列に循環的に代入する方法

WBOY
WBOYオリジナル
2016-06-13 12:35:27840ブラウズ

データベースからクエリされたツリー構造データを配列に循環的に割り当てるにはどうすればよいですか?
//データベース
ID 1 49d15b3a-1798-11e3-991e-001d608a0834 55ac840c-0f01-11e3-bcf6-001d608a0834 デザイン1部
49e24a33-1798-11e3-991e-001d608a0834 55ac840c-0f01-11e3-bcf6-001d608a0834 実装セクション 1
49f452aa-1798-11e3-991e-001d608a0834 55ac840c-0f01-11e3-bcf6-001d608a0834 品質検査部 1
5599eec4-0f01-11e3-bcf6-001d608a0834 f6597beb-0f00-11e3-bcf6-001d608a0834 マーケティング 1 部
55ac840c-0f01-11e3-bcf6-001d608a0834 f6597beb-0f00-11e3-bcf6-001d608a0834 研究開発部 1
55ca0dad-0f01-11e3-bcf6-001d608a0834 f6597beb-0f00-11e3-bcf6-001d608a0834 人事部 1
b5e86db9-0f01-11e3-bcf6-001d608a0834 f6667833-0f00-11e3-bcf6-001d608a0834 財務 1 部
b5f69ff5-0f01-11e3-bcf6-001d608a0834 f6667833-0f00-11e3-bcf6-001d608a0834 マネージャー 1
b60bc9b5-0f01-11e3-bcf6-001d608a0834 f6667833-0f00-11e3-bcf6-001d608a0834 物流部 1
f6597beb-0f00-11e3-bcf6-001d608a0834 03e782cd-0f00-11e3-bcf6-001d608a0834 1 つの会社 1
f6667833-0f00-11e3-bcf6-001d608a0834 03e782cd-0f00-11e3-bcf6-001d608a0834 第 2 会社 1
f6761c03-0f00-11e3-bcf6-001d608a0834 03e782cd-0f00-11e3-bcf6-001d608a0834 3 社 1
f683c3c7-0f00-11e3-bcf6-001d608a0834 03e782cd-0f00-11e3-bcf6-001d608a0834 4 社 1
f6955d9f-0f00-11e3-bcf6-001d608a0834 03e782cd-0f00-11e3-bcf6-001d608a0834 5 社 1
//phpメソッドコード
パブリック関数 getTreeModel() {
$sql = "*親ID が NULL のメニューツリーから選択";
$quer = $this->db->query($sql);
                                                 $row = $quer->result_array();
$data=array();
If ($quer->num_rows()>0) {
// 法人 $data=$this->getArray($row);
}
エコー数($data)."
";
return $data;
}
// このループの配列への代入に問題があります。 。 。このページには 1 番目と 2 番目のレベルのみが出力され、3 番目と 4 番目のレベルは出力されません。ただし、var_dump($row3) には値が含まれています。以下の方法についてアドバイスをお願いします
パブリック関数 getArray($row) {
$data=array();
foreach ($row as $val) {
                                                                      $arr1['id'] = $val['id'];
$arr1['menuname'] = $val['menuname'];
                                                                      $data[] = $arr1;
                                                                      $sql2 = "select *from menutree whereparentid ='$val[id]'";
$quer2 = $this->db->query($sql2);
            $row2 = $quer2->result_array();
            if ($quer2->num_rows()>0) {
                foreach ($row2 as $va2) {
                    $arr2['id'] = $va2['id'];
                    $arr2['メニュー名'] = $va2['メニュー名'];
                    
                    $data[] = $arr2;
                    
                     //echo $va2['menuname']."
";
                     $sql3 = "select *from menutree where parentid ='$va2[id]'";

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。