I’m building a small website with Symfony2 and Doctrine2. There are blog posts, events and press releases. Each of these is so similar that I decided to use single table inheritance (STI) with a parent table called ‘Node’.
Nodes have:
- a ‘published’ field, which is boolean
- a ‘locale’ field, which is a string and says ‘this is only to be shown in this locale’. (The locale is passed in via the request).
By default, I only want to display published nodes that are from the current locale.
Obviously, I could create lots of queries in the repository that look something like:
$this->createQueryBuilder('Event')
->where('Node.published = 1')
->where('Node.locale = :locale')
but this doesn’t seem very DRY.
So how do I build a default query which other queries can ‘inherit’ from? This should include default Doctrine queries based on relations.
Inheritance is probably overkill.
Why not just create a little factory method that gives you a preconfigured queryBuilder?
You could do the same thing, and simply override getQueryBuilder if you’re sure you always want your querybuilder configured that way.