Hallo mensen,

Hier mijn 'query':
<?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.

Iemand een idee?

M.v.g.
Dennis Mertens
Bump.

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).
En dan?

Even onderbouwen. Want met COUNT bereik ik niks.
COUNT() is een SQL functie die het aantal records telt. let wel op dat je dan het GROUP BY statement moet gebruiken in dit geval.
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!!!!!
Alleen met count kun je records tellen dus de oplossing heb je al, nu zul je hier mee moeten gaan spelen.
Sorry, maar ik kan zover ik weet niet het des gewenste resultaat terug krijgen.
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.
Ik heb een voorbeeld gegeven van wat ik wil ophalen, heeft niks met ruiken te maken. Dan lees je ook niet goed.

Maar ik wil het zo compact mogelijk houden.

Maar iig bedankt voor je 'moeite'.

Reageren