gpt4 book ai didi

php - 现有数据库中的 Symfony Doctrine Sluggable 扩展

转载 作者:行者123 更新时间:2023-12-04 02:10:57 25 4
gpt4 key购买 nike

我必须在现有实体中添加一个 slug 字段来对字段“名称”进行 slugify。但是这个实体中已经有数据,我无法删除它们。

我想创建一个控制台脚本,它可以对我所有的“名称”字段进行 slugify。

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

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;

最佳答案

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

关于php - 现有数据库中的 Symfony Doctrine Sluggable 扩展,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38482272/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com