Opinie :
CREATE TABLE `opinie` (
`id_opinie` INT(11) NOT NULL AUTO_INCREMENT,
`id_produkt_opinie` INT(11) NULL DEFAULT NULL,
`opinia_opinie` VARCHAR(255) NULL DEFAULT NULL,
`ocena_opinie` VARCHAR(5) NULL DEFAULT NULL,
`aktywny_opinie` ENUM('Y','N') NULL DEFAULT 'N',
PRIMARY KEY (`id_opinie`),
UNIQUE INDEX `id_opinie` (`id_opinie`)
)
Produkt :
CREATE TABLE `produkt` (
`id_produkt` INT(10) NOT NULL AUTO_INCREMENT,
`kod` VARCHAR(50) NOT NULL,
`tytul` VARCHAR(100) NOT NULL,
`opis` TEXT NOT NULL,
PRIMARY KEY (`id_produkt`),
UNIQUE INDEX `id_produkt` (`id_produkt`)
)
SELECT *, AVG(ocena_opinie) AS review_avg FROM produkt
LEFT JOIN opinie ON opinie.id_produkt_opinie = produkt.id_produkt AND aktywny_opinie = 'Y';
Product :
id | name | img |
________________________________________
1 | product1 | product1.jpg |
2 | product2 | product2.jpg |
3 | product3 | product3.jpg |
Review :
id | rating | product_id | activ |
________________________________________
1 | 4.0 | 1 | Y
2 | 5.0 | 1 | Y
3 | 3.0 | 1 | Y
4 | 4.0 | 2 | Y
5 | 5.0 | 2 | Y
Product3 id 3 NULL
I now have only one record displayed, how to do that for each of the product showed a number of opinions and AVG
Something like this, using a sub query to get the averages:-
SELECT Produkt.id_produkt,
Produkt.kod,
Produkt.tytul,
Produkt.opis,
opinie.id_opinie,
opinie.id_produkt_opinie,
opinie.opinia_opinie,
opinie.ocena_opinie,
opinie.aktywny_opinie,
review_avg
FROM produkt
LEFT JOIN opinie
ON opinie.id_produkt_opinie = produkt.id_produkt
AND aktywny_opinie = 'Y'
INNER JOIN
(
SELECT produkt.id_produkt , AVG(ocena_opinie) AS review_avg
FROM produkt
LEFT JOIN opinie
ON opinie.id_produkt_opinie = produkt.id_produkt
AND aktywny_opinie = 'Y'
GROUP BY produkt.id_produkt
) Sub1
ON Sub1.id_produkt = produkt.id_produkt