如何从数据库中的现有数据生成slug字段-条令Symfony2

如何从数据库中的现有数据生成slug字段-条令Symfony2,symfony,doctrine-orm,slug,Symfony,Doctrine Orm,Slug,这是我的实体,我使用了gedmo注释,当创建一个新寄存器(perits)时,slug可以正常工作,但如何从现有数据库自动生成slug文本 /** * @Gedmo\Slug(fields={"name"}) * @ORM\Column(type="string", unique=true) */ protected $slug; 您必须手动执行此操作,方法是选择所有不带slug的值,并将slug值设置为null,如Sluggable行为文档中所述 下面是一个简单的Symfony命令,用

这是我的实体,我使用了gedmo注释,当创建一个新寄存器(perits)时,slug可以正常工作,但如何从现有数据库自动生成slug文本

 /**
 * @Gedmo\Slug(fields={"name"})
 * @ORM\Column(type="string", unique=true)
 */
protected $slug;

您必须手动执行此操作,方法是选择所有不带slug的值,并将slug值设置为null,如Sluggable行为文档中所述


下面是一个简单的Symfony命令,用于重新生成给定类的所有slug:

<?php

namespace App\Command;

use App\Entity\Foo;
use App\Entity\Bar;
use Doctrine\Persistence\ManagerRegistry;
use Symfony\Component\Console\Command\Command;
use Symfony\Component\Console\Input\InputInterface;
use Symfony\Component\Console\Output\OutputInterface;

class RegenerateSlugs extends Command
{
    private $doctrine;

    protected static $defaultName = "app:regenerate-slugs";

    public function __construct(ManagerRegistry $doctrine)
    {
        parent::__construct();

        $this->doctrine = $doctrine;
    }

    protected function configure(): void
    {
        $this
            ->setDescription('Regenerate the slugs for all Foo and Bar entities.')
        ;
    }

    protected function execute(InputInterface $input, OutputInterface $output): void
    {
        $manager = $this->doctrine->getManager();

        // Change the next line by your classes
        foreach ([Foo::class, Bar::class] as $class) {
            foreach ($manager->getRepository($class)->findAll() as $entity) {
                $entity->setSlug(null);
                //$entity->slug = null; // If you use public properties
            }

            $manager->flush();
            $manager->clear();

            $output->writeln("Slugs of \"$class\" updated.");
        }
    }
}

你想用这个slug“persisted”做什么?你需要更新“name”字段-简单地持久化实体是行不通的。我认为gedmo专门监听对命名字段的更改。否则,您必须编写一个小函数来完成此操作。请在此处查看有关手动生成slug的更多信息: