php - Symfony2 Sonata 项目 sonata_type_model 与 OneToMany 实体 sortby

标签 php symfony doctrine-orm jquery-ui-sortable sonata-admin

我使用 Symfony2 和奏鸣曲管理员。我有一个拥有子类别的实体(新闻)。每个子类别拥有一个类别,每个类别拥有一个 Affaire。 在新闻的添加页面中,我有一个子类别列表,可以选择我的子类别来链接到我的新闻。我选择的每个项目的格式如下:

enter image description here

<li> subcategory (category'affaire) > categoryName </li>.

我想按事务 (ASC) 对字段进行排序。

这是我的表单域定义:

protected function configureFormFields(FormMapper $formMapper)
    {
        $formMapper
            ->add('subCategory', 'sonata_type_model', array("label" => "Catégorie/Sous Catégorie", "btn_add" => false));
}

一条新闻拥有一个子类别

一个子类别拥有一个类别

一个类别拥有一个事务。

我尝试添加类似的内容:

    ->add('subCategory', 'sonata_type_model', 
            array("label" => "Sub Category",
                  "btn_add" => false
            ), 
            array(
                'sortable'      => 'ordering',
                'label'         => 'subcategory.category.affaire.code',
            ))

但是什么都没有改变。有什么想法吗?

类别实体:

class NewsCategory
{
    /**
     * @var \My\Custom\Foo\Entity\Affaire
     *
     * @ORM\ManyToOne(targetEntity="\My\Custom\Foo\Entity\Affaire")
     * @ORM\JoinColumn(name="affaire_code", referencedColumnName="code")
     */
    private $affaire;

-- 子类别实体:

class NewsSubCategory
{
    /**
     * @var \My\Custom\Foo\Entity\NewsCategory
     *
     * @ORM\ManyToOne(targetEntity="\My\Custom\Foo\Entity\NewsCategory")
     * @ORM\JoinColumn(name="category_ref", referencedColumnName="id")
     * 
     */
    private $category;

-- 新闻实体:

class News
{
    /**
     * @var \My\Custom\Foo\Entity\NewsSubCategory
     *
     * @ORM\ManyToOne(targetEntity="\My\Custom\Foo\Entity\NewsSubCategory")
     * @ORM\JoinColumn(name="sub_category", referencedColumnName="id")
     */
    private $subCategory;

[编辑]:

我试过了

->add('subCategory', 'sonata_type_model',array("label" => "Catégorie/Sous Catégorie","btn_add" => false), array("sortable" => "ordering"))

我没有犯错误,但什么也没发生。我不明白我可以在哪里添加选项 (orderBy => 'Affaire') ,或者是否必须这样做......

[编辑2]:

我什至尝试过:

->add('subCategory.category.affaire', null,
                    array("label" => "Catégorie/Sous Catégorie",
                            "btn_add" => false
                    ))

最佳答案

我不知道如何使用 sonata_type_model 做到这一点,但您可以将字段的类型更改为 null 或实体(null 设置默认类型)并添加 query_builder 选项来调整所使用的查询:

->add('subcategory', null, array(
    'query_builder' => function(EntityRepository $er) {
        return $er->createQueryBuilder('sc')
            ->leftjoin('sc.category', 'c')
            ->orderBy('c.affaire', 'ASC');
    }
))

如果您选择实体而不是 null,则还必须添加类:

->add('subcategory', 'entity', array(
    'class' => 'MyCustomFooBundle:Subcategory',
    'query_builder' => function(EntityRepository $er) {
        return $er->createQueryBuilder('sc')
            ->leftjoin('sc.category', 'c')
            ->orderBy('c.affaire', 'ASC');
    }
))

关于php - Symfony2 Sonata 项目 sonata_type_model 与 OneToMany 实体 sortby,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33411122/

相关文章:

php - MySQL JOINS 用例

php - Doctrine2 和原始 sql : get last inserted ID

forms - 带有 Assets 的 symfony 自定义表单类型

doctrine-orm - Doctrine 2 中的类表继承映射 : How to get type info from entity

c# - 使用 C# 调用 php 脚本 (Unity)

php - 仅在 IE11 中不设置 session Cookie

symfony - FOSUserBundle 验证 Controller 中的电子邮件

Symfony:为拒绝访问的安全选民提供消息?

javascript - 如何使用两点经纬度绘制行车路线路径

PhpExcel:如何模拟excel拖动单元格内容