如何在嵌套集中搜索,并以树形结构恢复过滤后的数据?
例如:
根
|
CAT1:
我搜索'subc2'
根
|
CAT2:
这是我的测试表夹具:
FokonyviKategoria:
fok0:
megnevezes: Főkönyvi kategóriák
children:
fok1:
megnevezes: Főkönyvi teszt 1
fok2:
megnevezes: Főkönyvi teszt 2
fok3:
megnevezes: Főkönyvi teszt 3
children:
fok4:
megnevezes: Főkönyvi teszt 4
fok5:
megnevezes: Főkönyvi teszt 5
表格定义:
FokonyviKategoria:
actAs:
NestedSet:
hasManyRoots: false
columns:
megnevezes: string(255)
relations:
Szamlak:
type: many
local: id
foreign: fokonyvi_kategoria_id
foreignAlias: FokonyviKategoria
这是我的尝试:
$treeObject = Doctrine_Core::getTable('EszkozKategoria')->getTree();
$q = Doctrine_Query::create()
->select('e.megnevezes')
->from('EszkozKategoria e')
->where('megnevezes LIKE "%fúró%"');
$treeObject->setBaseQuery($q);
$tree = $treeObject->fetchTree();
$treeObject->resetBaseQuery();
$query = $treeObject->getBaseQuery();
$query->setHydrationMode(Doctrine_Core::HYDRATE_ARRAY_HIERARCHY);
$treeObject->setBaseQuery($query);
foreach ($tree as $node) {
//$treeObject2 = Doctrine_Core::getTable('EszkozKategoria')->getTree();
//$tmp = $treeObject2->fetchBranch($node->id, array('depth' => 3), Doctrine_Core::HYDRATE_ARRAY_HIERARCHY);
//var_dump($tmp);
//echo $node->getNode()->getPath(' / ', true) . "\n";
$a = $node->getNode()->getAncestors();
var_dump($a);
}
我想要节点和所有祖先。
答案 0 :(得分:0)
我会这样:
$listLeaf = FokonyviKategoriaTable::getInstance()->createQuery()
->where('level = ?', 2) //all leaf
->fetchArray();
$list = array();
foreach ($listLeaf as $id => $node) {
$list[$node['id']] = $nade['megnevezes'];
$list['ancestors'] = $node->getNode()->getAncestors();
}
return $list;