Symfony2灯具订单 - 更好的方式

时间:2015-10-20 10:51:22

标签: symfony doctrine fixtures

在DoctrineFixturesBundle中,如果我想按指定的顺序执行灯具,我必须在任何灯具类方法中创建如下:

public function getOrder()
{
    return 2;
}

指定订单并不舒服。

在Laravel Framework中我可以这样做:

class DatabaseSeeder extends Seeder
{
    public function run()
    {
        $this->call('PositionsSeeder');
        $this->call('UsersSeeder');
        $this->call('PostsSeeder');
    }
}

我的问题是:我可以在symfony中这样做吗?

我看到一个解决方案。我可以使用以下代码制作BaseFixture:

class LoadBrandData extends AbstractFixture
{
    public function load(ObjectManager $manager)
    {
        (new LoadPositionsData())->load(manager);
        (new LoadUsersData())->load(manager);
        (new LoadPostsData())->load(manager);

    }
}

但也许我可以做得更好。我可以吗?

4 个答案:

答案 0 :(得分:5)

即使你不喜欢它,实现这一目标的最佳方法是通过getOrder()方法。

话虽如此,您可以使用至少两种技巧以其他方式设置订单:

  • 在一个文件中定义所有灯具。只有你没有定义很多灯具才有意义。
  • 在一个目录中定义所有灯具,并将加载顺序作为文件名的一部分(按字母顺序加载)。这仅在您按照单捆绑方法开发Symfony应用程序时才有效。

答案 1 :(得分:1)

这就是我的工作。

创建一个存储负载顺序的类。

<?php

namespace AppBundle\DataFixtures;

use AppBundle\DataFixtures\ORM\LoadClientData;
use AppBundle\DataFixtures\ORM\LoadRoleData;
use AppBundle\DataFixtures\ORM\LoadUserData;

class Order
{
    const FIXTURES = [
        LoadRoleData::class,
        LoadUserData::class,
        LoadClientData::class,
    ];
}

然后,在您的抽象fixture类(将由所有其他灯具继承的类)中,创建以下方法:

    /**
     * @return int
     * @throws \Exception
     */
    public function getOrder()
    {
        $order = array_search(get_called_class(), Order::FIXTURES);

        if ($order === false) {
            throw new \Exception('Seems like you forgot to put things in Order');
        }

        return $order;
    }

你永远不应该直接从灯具本身调用getOrder方法。

答案 2 :(得分:1)

您可以使用Doctrine DependentFixtureInterface ;请检查以下示例:

namespace MyDataFixtures;

use Doctrine\Common\DataFixtures\AbstractFixture;
use Doctrine\Common\DataFixtures\DependentFixtureInterface;
use Doctrine\Common\Persistence\ObjectManager;

class MyFixture extends AbstractFixture implements DependentFixtureInterface
{
    public function load(ObjectManager $manager)
    {}

    public function getDependencies()
    {
        return array('MyDataFixtures\MyOtherFixture'); // fixture classes fixture is dependent on
    }
}

class MyOtherFixture extends AbstractFixture
{
    public function load(ObjectManager $manager)
    {}
}

来源:https://github.com/doctrine/data-fixtures

答案 3 :(得分:0)

您还可以使用前缀为灯具文件命名

00-MyFirstFixtures.php
01-MySecondFixtures.php
02-MyThirdFixtures.php

...等

很显然,别忘了用相同的方式命名您的班级

class 00-MyFirstFixtures extends Fixture
{
  ...
}