I’m new to the QueryBuilder and I’m trying to do a POST request (with a JSON) to retrieve some informations in my database.
I’m using array because each property can have several values. Here’s the JSON I’m currently sending :
x
{
"name":["Martin"],
"state":["Ohio", "Texas"],
"job":["Photographer", "Reporter"]
}
Here’s my database :
ID | NAME | FIRST_NAME | STATE | JOB | SPEAK_FRENCH
1 | Martin | John | Ohio | Photographer | 1
2 | Martin | Max | Ohio | Reporter | 1
3 | Martin | Sophie | Texas | Model | 1
4 | Alexander | David | Kansas | Author | 0
5 | Archie | Kira | Maine | Photographer | 1
6 | Lushen | Albert | Nevada | Pilot, Model | 1
7 | Wilkins | Minnie | Utah | Tailor | 0
8 | Martin | Thomas | Texas | Reporter | 1
9 | Patino | Stephen | Virginia | Pilot, Reporter | 1
10 | Ting | Maria | Nevada | Dentist | 0
11 | Brown | Barbara | Virginia | Reporter | 1
12 | Martin | William | Texas | Photographer | 1
13 | Zachary | Thomas | Virginia | Telephonist | 1
The request I would like to have :
SELECT * FROM 'application'
WHERE SPEAK_FRENCH = 1
AND NAME = "Martin"
AND STATE = "Ohio"
AND JOB LIKE "%Photographer%"
OR SPEAK_FRENCH = 1
AND NAME = "Martin"
AND STATE = "Ohio"
AND JOB LIKE "%Reporter%"
OR SPEAK_FRENCH = 1
AND NAME = "Martin"
AND STATE = "Texas"
AND JOB LIKE "%Photographer%"
OR SPEAK_FRENCH = 1
AND NAME = "Martin"
AND STATE = "Texas"
AND JOB LIKE "%Reporter%"
And what I have currently done in Symfony, doesn’t work the way I want it to :
$repository = $this->getDoctrine()->getRepository(Application::class);
$query = $repository->createQueryBuilder('request');
$temp_name = 0;
$temp_state = 0;
$temp_job = 0;
foreach ($app->getName() as $name) {
$temp_name = $temp_name + 1;
$query = $query->orWhere('request.speakFrench = 1')
->andWhere('request.name LIKE :JSONname' . strval($temp_name))
->setParameter('JSONname' . strval($temp_name), $name);
foreach ($app->getState() as $state) {
$temp_state = $temp_state + 1;
$query = $query->andWhere('request.state LIKE :JSONstate' . strval($temp_state))
->setParameter('JSONstate' . strval($temp_state), $state);
foreach ($app->getJob() as $job) {
$temp_job = $temp_job + 1;
$query = $query->andWhere('request.job LIKE :JSONjob' . strval($temp_job))
->setParameter('JSONjob' . strval($temp_job), '%' . $job . '%');
}
}
}
My goal is to get this result :
ID | NAME | FIRST_NAME | STATE | JOB | SPEAK_FRENCH
1 | Martin | John | Ohio | Photographer | 1
2 | Martin | Max | Ohio | Reporter | 1
8 | Martin | Thomas | Texas | Reporter | 1
12 | Martin | William | Texas | Photographer | 1
My code isn’t working well, it doesn’t send any error but only return ID : 8
.
I’m looking for a way to do the query that returns only the ID : 1, 2, 8 and 12
.
Thanks a lot for your future answers.
P.S : I’m running Symfony 4.3.11.
Advertisement
Answer
With Doctrine you can do for exemple:
$queryBuilder = $this->createQueryBuilder('request');
$queryBuilder
->andWhere($queryBuilder->expr()->andX(
$queryBuilder->expr()->eq('user.speakFrench', ':speakFrench'),
$queryBuilder->expr()->like('request.name', ':name'),
$queryBuilder->expr()->in('request.state', ':states'),
$queryBuilder->expr()->in('request.job', ':jobs'),
))
->setParameter('speakFrench', true)
->setParameter('name', 'Martin')
->setParameter('states', ['Ohio', 'Texas'])
->setParameter('jobs', ['Photographer', 'Reporter'])
->getQuery()
->getResult();
That should be a good start.
To continue:
- Many examples of Doctrine usage: Hot examples
- Check DoctrineORMQueryExpr class, there’s a lot of useful functions. Doctrine Expr GitHub
- Check the documentation that provides many examples: Doctrine Query Builder