<?php
$qSearch = $objSql->query("
(SELECT
name, 'movie' AS section
FROM
movie
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%')
UNION ALL
(SELECT
name, 'genre' AS section
FROM
genre
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%')
UNION ALL
(SELECT
name, 'reek' AS section
FROM
reek
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%')
ORDER BY
CASE WHEN
'".$_POST['rank']."' = 'alphabetical'
THEN
name
ELSE
section
END
");
Nu krijg ik als de rank post section is genre, movie en reek onder elkaar.
Bijv:
Genre
Action
Urban
Movie
basblabl
OZ season 4
OZ season 1
OZ season 5
OZ season 2
OZ season 6
OZ season 3
Reek
Alle Oz dingen!!!
Maar nu wil ik achter Genre, Movie en Reek tussen haakjes het aantal gevonden genres, movies of reeks.
Dit dus:
Genre (2)
Action
Urban
Movie (7)
basblabl
OZ season 4
OZ season 1
OZ season 5
OZ season 2
OZ season 6
OZ season 3
Reek (1)
Alle Oz dingen!!!
Normaal gesproken wordt het aantal records met num_rows gedaan, maar dan krijg ik het totaal aantal gevonden records.
Ik ben even verder gegaan en ben nu bezig met multi_query, more_results en next_result.
Mijn query ziet er nu zo uit:
<?php
$objSql->multi_query("
SELECT
name, 'genre' AS section
FROM
genre
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%'
;
SELECT
name, 'movie' AS section
FROM
movie
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%'
;
SELECT
name, 'reek' AS section
FROM
reek
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%'
");
Helaas kan ik nu nog werken met ORDER BY name, zodat de resultaten van de verschillende queries door elkaar staan (alfabetisch).
Ja en nu even graag aandacht bieden. Want met COUNT krijg ik niet het gewenste resultaat. Krijg ik ben elk record een 1. Omdat elke naam maar 1 keer voorkomt.
Edit Query
<?php
$qSearch = $objSql->query("
(SELECT
name, 'movie' AS section, COUNT(*) AS total
FROM
movie
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%'
GROUP BY
name)
UNION ALL
(SELECT
name, 'genre' AS section, COUNT(*) AS total
FROM
genre
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%'
GROUP BY
name)
UNION ALL
(SELECT
name, 'reek' AS section, COUNT(*) AS total
FROM
reek
WHERE
name LIKE '%".$objSql->real_escape_string($_POST['term'])."%'
GROUP BY
name)
ORDER BY
CASE WHEN
'".$objSql->real_escape_string($_POST['rank'])."'='alphabetical'
THEN
name
ELSE
section
END
");
Resultaat
Genre (1)
Humor
Action
Movie (1)
OZ season 4
OZ season 1
OZ season 5
OZ season 2
OZ season 6
OZ season 3
Reek (1)
Alle Oz dingen!!!
OZ!!!!!
Mogelijk zul je 2 queries moeten gebruiken, ik kan zo ook niet ruiken natuurlijk wat je nu exact wil ophalen. Het is niet verkeerd om meerdere queries te gebruiken. Vaak is het zelfs sneller om een paar simpele queries te maken ipv een hele lange.