Search code examples
mysqlratingreview

MySQL Review rating


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


Solution

  • 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