我有一个小型 symfony2 应用程序,用户可以在其中创建页面。每个页面都应该可以通过路由 /{user_slug}/{page_slug} 访问。我有实体用户和页面,我对这两个实体都使用了 sluggable 行为。为了找到正确的页面,user_slug 和 page_slug 的组合必须是唯一的。
检查 user_slug 和 page_slug 的组合是否唯一的最佳方法是什么?
在你的存储库中试试这个:
public function findByUsernameAndSlug($username, $slug)
{
$em = $this->getEntityManager();
$query = $em->createQuery("
SELECT g
FROM Acme\PagesBundle\Entity\Page p
JOIN p.owner u
WHERE u.username = :username
AND p.slug = :slug
")
->setParameter('username', $username)
->setParameter('slug', $slug);
foreach ($query->getResult() as $goal) {
return $goal;
}
return null;
}
在将实体保留在服务层中之前,请检查给定的用户和页面 slug 组合是否唯一,如果没有修改页面 slug(附加-2
或类似的东西)或抛出异常:
public function persistPage(Page $page) {
$userSlug = $page->getUser()->getSlug();
$pageSlug = $page->getSlug();
if ($this->pagesRepository->findOneBySlugs($userSlug, $pageSlug) != null) {
// given combination already exists
throw new NonUniqueNameException(..);
// or modify the slug
$page->setSlug($page->getSlug() . '-2');
return $this->persistPage($page);
}
return $this->em->persist($page);
}
// PagesRepository::findOneBySlugs($userSlug, $pageSlug)
public function findOneBySlugs($userSlug, $pageSlug) {
$query = $this->em->createQueryBuilder('p')
->addSelect('u')
->join('p.user', 'u')
->where('p.slug = :pageSlug')
->where('u.slug = :userSlug;)
->getQuery();
$query->setParameters(combine('userSlug', 'pageSlug'));
return $query->getSingleResult();
}