首页 > 解决方案 > Symfony 4 / 学说插入初始数据库数据

问题描述

我正在使用 symfony 4.2 并寻找一种将初始数据插入数据库的方法。我试图创建的是类似于初始设置脚本的东西,它可以通过控制台命令调用一些 sql 插入(如固定装置,但也适用于生产环境)。

我正在考虑在教义迁移类中使用 postUp 函数,但我不想为我设置的每个生产环境重写此函数。有没有办法为此目的使用学说迁移功能,还是有首选方法?

示例工作流程:

标签: phpsymfonydoctrinedoctrine-migrations

解决方案


在生产中使用学说夹具包

虽然不鼓励这样做,因为您可能会因此意外删除生产数据库,但我确实看到了一些在生产环境中使用 dotrine 固定装置包的有效用例。

您可以编辑您的config/bundles.php以在生产环境中启用学说夹具捆绑包。

改变

Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle::class => ['dev' => true, 'test' => true],

Doctrine\Bundle\FixturesBundle\DoctrineFixturesBundle::class => ['all' => true],

创建自己的夹具加载命令

也不鼓励使用教义功能手动加载夹具,但这样您可以添加额外的检查,例如只填充新的数据库。

$fixtures = (new \Doctrine\Common\DataFixtures\Loader())->loadFromDirectory(__DIR__ . '/../src/DataFixture');
$loader = new \Doctrine\Bundle\FixturesBundle\Loader\SymfonyFixturesLoader(new \Symfony\Component\DependencyInjection\Container());
$loader->addFixtures(
    array_map(
        function ($fixture) {
            return [
              'fixture' => $fixture,
              'groups' => []
            ];
        },
        $fixtures
    )
);

$purger = new Doctrine\Common\DataFixtures\Purger\ORMPurger($entityManager);

$executor = new Doctrine\Common\DataFixtures\Executor\ORMExecutor($entityManager, $purger);
$executor->execute(
    $loader->getFixtures()
);

推荐阅读