Wie man in yii2 zählt und gruppiert

Lesezeit: 3 Minuten

Benutzeravatar von deacs
deaks

Ich möchte folgende Abfrage mit yii2 generieren:

SELECT COUNT(*) AS cnt FROM lead WHERE approved = 1 GROUP BY promoter_location_id, lead_type_id

Ich habe versucht:

$leadsCount = Lead::find()
->where('approved = 1')
->groupBy(['promoter_location_id', 'lead_type_id'])
->count();

Was diese Abfrage generiert:

SELECT COUNT(*) FROM (SELECT * FROM `lead` WHERE approved = 1 GROUP BY `promoter_location_id`, `lead_type_id`) `c`

In yii 1.x hätte ich folgendes gemacht:

$criteria = new CDbCriteria();
$criteria->select="COUNT(*) AS cnt";
$criteria->group = array('promoter_location_id', 'lead_type_id');

Vielen Dank!

  • Sie können den Befehl create verwenden, um Ihre MySQL-Abfrage zu schreiben

    – Kschiz

    25. Juni 2014 um 8:55 Uhr

  • Bitte poste die Lösung als Antwort.

    – Cthulhu

    26. Juni 2014 um 13:43 Uhr


Benutzeravatar von deacs
deaks

Lösung:

$leadsCount = Lead::find()
->select(['COUNT(*) AS cnt'])
->where('approved = 1')
->groupBy(['promoter_location_id', 'lead_type_id'])
->all();

und hinzufügen public $cnt zum Modell, in meinem Fall Blei.

Wie Kshitiz auch sagte, könnte man auch einfach verwenden yii\db\Query::createCommand().

  • Dies funktioniert und ich musste die öffentliche Variable zur Modellklasse hinzufügen und von @deacs erwähnen und die Methode all () durch ersetzen ->createCommand()->queryAll(); Beachten Sie auch, dass meine Methode select() Vielfache hat ->select(['type, date(significant_timestamp) AS significant_timestamp, COUNT(*) AS size'])

    – Gajen Sunthara

    5. September 2017 um 19:18 Uhr


Sie können die Anzahl erhalten, indem Sie verwenden zählen() in der Auswahlabfrage

$leadCount = Lead::find()
->where(['approved'=>'1'])
->groupBy(['promoter_location_id', 'lead_type_id'])
->count();

Referenzlink für verschiedene Funktionen der Auswahlabfrage

Wenn Sie nur an der Zählung interessiert sind, verwenden Sie yii\db\Query wie von anderen erwähnt. Es sind keine Änderungen an Ihrem Modell erforderlich:

$leadsCount = (new yii\db\Query())
    ->from('lead')
    ->where('approved = 1')
    ->groupBy(['promoter_location_id', 'lead_type_id'])
    ->count();

Hier ist ein Link zum Yii2-API-Dokumentation

Benutzeravatar von t6nnp6nn
t6nnp6nn

Ohne das hinzuzufügen $cnt Eigenschaft zu modellieren

$leadsCount = Lead::find()
->select(['promoter_location_id', 'lead_type_id','COUNT(*) AS cnt'])
->where('approved = 1')
->groupBy(['promoter_location_id', 'lead_type_id'])
->createCommand()->queryAll();

Nur eine Anmerkung, falls es jemandem hilft, dass ein Getter, der als Eigenschaft verwendet wird, zählbar ist (während er, wenn er als Funktion aufgerufen wird, 1 zurückgibt). In diesem Beispiel habe ich eine Category-Klasse mit Listings, die durch „listing_to_category“ verbunden sind. Um aktive, genehmigte Einträge für die Kategorie zu erhalten, gebe ich eine ActiveQuery zurück, also:

/**
 * @return \yii\db\ActiveQuery
 */
public function getListingsApprovedActive() {
        return $this->hasMany(Listing::className(), ['listing_id' => 'listing_id'])
                                ->viaTable('listing_to_category', ['category_id' => 'category_id'])
                                ->andWhere(['active' => 1])->andWhere(['approved' => 1]);
}

Beim Aufrufen der Anzahl der Eigenschaften der Kategorie wird die Datensatzanzahl zurückgegeben:

count($oCat->listingsApprovedActive)

Der Aufruf von count für die Funktion gibt 1 zurück:

count($oCat->getListingsApprovedActive())

1430440cookie-checkWie man in yii2 zählt und gruppiert

This website is using cookies to improve the user-friendliness. You agree by using the website further.

Privacy policy