3

我必须在现有实体中添加一个 slug 字段来填充字段“名称”。但是这个实体中已经有数据了,我不能删除它们。

我想创建一个控制台脚本,它可以使我所有的“名称”字段都变得模糊。

我不知道该怎么做,因为这不是插入,而只是更新...

class SlugCommand extends ContainerAwareCommand
{
    protected function configure()
    {
        $this
            ->setName('generate:geo:slug')
            ->setDescription('Slug generation for GeoBundle ');
    }

    protected function execute(InputInterface $input, OutputInterface $output)
    {
        $em = $this->getContainer()->get('doctrine')->getManager();
        $regions = $em->getRepository('FMGeoBundle:Region')->findAll();

        if($regions === null){
            throw new Exception('No Region found');
        }

        foreach($regions as $region){
            // ????? Generate the slug here ??
            $em->persist($region);
        }

        $em->flush();
        $output->writeln('Slugs Generated ;) ...');
    }
}

我实体中的“slug”字段:

/**
 * @var string
 *
 * @ORM\Column(name="slug", type="string", length=255)
 * @Gedmo\Slug(fields={"name"})
 */
protected $slug;
4

3 回答 3

2

Sluggable 扩展适用于创建更新操作。因此,您可以通过将行的名称与其自己的名称一起模拟更新。

于 2016-07-20T19:15:25.857 回答
2

我找到了一个更简单的方法。您显然可以像这样手动设置 slug。它将扼杀所需的领域。

foreach ($regions as $region) {
     $region->setSlug($region->getName());

     $this->em->persist($region);
}
于 2016-07-21T07:40:33.340 回答
0

刚刚看到Gedmo 库文档直接回答了这个问题:

再生蛞蝓

如果您希望 slug 基于 sluggable 字段重新生成自身,请将 slug 设置为 null。

<?php $entity = $em->find('Entity\Something', $id);
$entity->setSlug(null);

$em->persist($entity); $em->flush();

所以,在你的情况下,你只需要坚持实体,没有别的。因为 $slug 已经为空。

于 2016-07-26T16:12:31.247 回答