我正在使用我的个人项目:
Doctrine v2.6.3
StofDoctrineExtensionsBundle以管理树结构。
我确实设置了名为FileTree
的树结构(代表目录和文件)。我在树中添加了几个自定义字段:item_name
,item_extension
,item_sort_value
和is_file
。
我无法获得文件树中按字段item_sort_value
排序的文件夹和文件!
同时,当仅在自定义缓存器中检索文件时,我可以对项目进行排序(根据需要)。
检索(完整大小)文件夹文件树
public function getFileTreeNodeArray($file_tree_root_id): array
{
$em = $this->getEntityManager();
$query = $em
->createQueryBuilder()
->select('ft')
->from(FileTree::class, 'ft')
->where('ft.root = :root_id')
->setParameter('root_id', $file_tree_root_id)
->orderBy('ft.root, ft.lft', 'ASC')
//->addOrderBy('ft.itemSortValue', 'ASC')
->getQuery();
$query->setHint(\Doctrine\ORM\Query::HINT_INCLUDE_META_COLUMNS, true);
return $query->getArrayResult();
}
检索文件夹中的文件
public function getFileTreeNodeContentFilesByUploaderArray($file_tree_node_id, $user_id): array
{
$em = $this->getEntityManager();
$is_file = true;
$query = $em
->createQueryBuilder()
->select('ft')
->from(FileTree::class, 'ft')
->where('ft.parent = :file_tree_node_id')
->andWhere('ft.isFile = :is_file')
->andWhere('ft.uploader = :user_id')
->setParameter('file_tree_node_id', $file_tree_node_id)
->setParameter('is_file', $is_file)
->setParameter('user_id', $user_id)
->orderBy('ft.itemSortValue', 'ASC')
->getQuery();
$query->setHint(\Doctrine\ORM\Query::HINT_INCLUDE_META_COLUMNS, true);
return $query->getArrayResult();
}
我尝试使用reorder
和reorderAll
,但“无济于事”。
一个例子
public function reorderFileTreeBranch($parent_id): void
{
$repo_file_tree = $this->entityManager->getRepository(FileTree::class);
$branch_node = $repo_file_tree->findOneBy(['id' => $parent_id]);
$repo_file_tree->reorder($branch_node, 'item_sort_value', 'ASC');
$this->entityManager->flush();
}
我可以在reorder
中看到许多其他SQL查询(无论何时使用reorderAll
或Symfony profiler
),因此肯定会发生某些事情,但是之后-各项的排序相同在树上...
我做错什么了吗?
欢迎您提出想法和答案!
答案 0 :(得分:0)
好吧,经过多次尝试和失败,我设法使它按预期工作。
原来reorder
中的NestedTreeRepositoryTrait
在成功时未返回true ...我已将其修复-因此-现在可以按预期的顺序将炒锅订购了。