web-dev-qa-db-ja.com

yii2でカウントおよびグループ化する方法

Yii2を使用して次のクエリを生成したいと思います。

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

私が試してみました:

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

このクエリを生成するもの:

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

yii 1.xでは、次のことを行います。

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

ありがとう!

19
deacs

溶液:

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

そして_public $cnt_をモデルに追加します。私の場合はLeadです。

Kshitizも述べているように、yii\db\Query::createCommand()を使用することもできます。

24
deacs

カウントだけに興味がある場合は、他の人が述べたようにyii\db\Queryを使用してください。モデルを変更する必要はありません。

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

ここに Yii2 APIドキュメント へのリンクがあります

8
Harman Dhillon

選択クエリでcount()を使用してカウントを取得できます

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

参照リンク 選択クエリのさまざまな機能

8
Kailas

$cntプロパティをモデルに追加せずに

$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();
1
t6nnp6nn

プロパティとして使用されるゲッターはカウント可能であることに注意してください(関数として呼び出された場合は1を返します)。この例では、listing_to_categoryで結合されたリストを持つCategoryクラスがあります。カテゴリのアクティブな承認済みリストを取得するには、ActiveQueryを返します。したがって、

/**
 * @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]);
}

Categoryのプロパティでcountを呼び出すと、レコードカウントが返されます。

count($oCat->listingsApprovedActive)

関数の呼び出し回数は1を返します:

count($oCat->getListingsApprovedActive())
0
Rich Harding