0

ユーザーがページを作成できる小さな symfony2 アプリケーションがあります。各ページはルート /{user_slug}/{page_slug} 経由でアクセスできる必要があります。ユーザーとページのエンティティがあり、両方のエンティティにスラッグ可能な動作を使用します。正しいページを見つけるには、user_slug と page_slug の組み合わせが一意である必要があります。

user_slug と page_slug の組み合わせが一意であることを確認する最良の方法は何ですか?

4

2 に答える 2

1

前置詞でこれを試してください:

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;
}
于 2012-06-10T11:43:25.060 に答える
0

サービス層でエンティティを永続化する前に、指定されたユーザーとページ スラッグの組み合わせが一意であるかどうかを確認します。そうでない場合は、ページ スラッグを変更 (追加-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();
}
于 2012-06-10T11:44:22.963 に答える