sql >> Databasteknik >  >> RDS >> Mysql

Yii2 :Konvertera en rå fråga till ActiveRecord

Om RawSql-frågan du skrev ger dig önskade resultat om den körs på bordet med phpmyadmin eller något annat verktyg kan du omvandla det till följande.

$subQuery = Adanalytics::find()
        ->select([new Expression('[[id]], [[ad_id]], MAX([[impression]]) as impression, max([[view]]) as view, max([[clicks]]) as clicks,[[visitor_ip]],[[publisher_id]]')])
        ->where(['publisher_id' =>  Yii::$app->user->identity->id ])->
        ->groupBy('[[id]], [[visitor_ip]]');

$query = Adanalytics::find()
        ->select([new \yii\db\Expression('t.[[date_event]], t.[[id]], t.[[ad_id]], sum(t.[[impression]]) as total_impression, sum(t.[[view]]) 
         as total_views, sum(t.[[clicks]]) as total_clicks, t.[[publisher_id]], i.[[budget]],i.[[name_of_campaign]]')])
        ->from(['t' => $subQuery])
        ->innerJoin('{{%inventory}} i', 'i.id=t.ad_id')
        ->groupBy('t.ad_id, t.date_event');
$query->all()

Se bara till att de främmande nycklarna som du använder för att gå med i de andra tabellerna ska anges i select, annars kan det ge dig ett fel som kolumn ej hittad / eller okänd kolumn.



  1. Blanda isoleringsnivåer i PostgreSQL

  2. MySQL Insert Select - NOT NULL-fält

  3. Kan någon hjälpa till att förklara varför det är dåligt och fel att använda en SQL JOIN?

  4. Ta bort dubbletter av rader från en tabell