sql >> Database teknologi >  >> RDS >> Mysql

Hvordan får man en gennemsnitlig bedømmelse pr. produkt ved hjælp af codeigniter-forespørgsel?

få data fra tabel vurderinger , ved at bruge en venstre joinforbindelse med vælg for gennemsnittet.

join()-funktionen af Codeigniter giver dig mulighed for at skrive en valgt del i stedet for tabelnavnet, men du skal placere den i parentes:

$this->db->select('t1.*, t2.avg_rating, t3.*');
$this->db->from('ratings t1');
$this->db->join('
                  (select product_id, avg(rating) as avg_rating 
                   from ratings 
                   group by product_id)  t2','t2.product_id=t1.product_id','left'
                );
$this->db->join('users t3','t3.id=t1.user_id','left'); 
$this->group_by('t1.userid')
$this->db->get()->result();

genererer:

SELECT t1.*, t2.avg_rating, t3.*
FROM ratings t1
left join 
        (select product_id, avg(rating) as avg_rating from ratings group by product_id)  t2 
    on t2.product_id=t1.product_id
left join users t3
    on t1.user_id = t3.id
group by t1.user_id

og output som du forventer.



  1. Gå i dvale ved at sende overflødige forespørgsler til databasen

  2. Integrering af ssl med mysql - Adgang nægtet

  3. %ENV virker ikke, og jeg kan ikke bruge delt bibliotek

  4. Kan ikke oprette forbindelse til fjernbasen Heroku Postgres ved hjælp af Play Framework 2.2.2