使用symfony4,doctrine2和stofDoctrineExtensionsBundle按任意字段对Gedmo树进行排序

时间:2019-03-13 16:54:33

标签: php symfony tree symfony4 stofdoctrineextensions

简介

我正在使用我的个人项目:

  • Windows 10专业版
  • 使用PHP v7.2.14的XAMPP
  • Postgres v10.6
  • Symfony v4.2.4
  • Doctrine v2.6.3

  • StofDoctrineExtensionsBundle以管理树结构。

设置

我确实设置了名为FileTree的树结构(代表目录和文件)。我在树中添加了几个自定义字段:item_nameitem_extensionitem_sort_valueis_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();
}

file tree example

  

检索文件夹中的文件

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();
}

files in the folder

我尝试过的

我尝试使用reorderreorderAll,但“无济于事”。

  

一个例子

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查询(无论何时使用reorderAllSymfony profiler),因此肯定会发生某些事情,但是之后-各项的排序相同在树上...

结论

我做错什么了吗?

欢迎您提出想法和答案!

1 个答案:

答案 0 :(得分:0)

好吧,经过多次尝试和失败,我设法使它按预期工作。 原来reorder中的NestedTreeRepositoryTrait在成功时未返回true ...我已将其修复-因此-现在可以按预期的顺序将炒锅订购了。