yii2:如何计算 groupby 查询的总和
yii2: how to calculate the sum of a groupby query
我正在尝试计算 groupby 查询的总和并将该值发送到 yii2 中的视图。我当前的代码获取并显示了正确的分组,但总和不起作用。
控制器代码如下:
public function actionIndex()
{
if( Yii::$app->request->post('search') )
{
$from = Yii::$app->request->post('from');
$to = Yii::$app->request->post('to');
switch( Yii::$app->request->post('activity') )
{
case 'bills':
$searchModel = new Bill();
$query = $searchModel::find();
$query->where(['BETWEEN', 'teis_bill_purchase_date', $from, $to]);
// The problem is in the below sum
$query->joinWith('inventory');
$query->groupBy('teis_inventory_id');
$query->sum('teis_bill_override_cbm');
$query->all();
$dataProvider = new ActiveDataProvider([
'query' => $query,
]);
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
'show_results' => 1
]);
break;
}
}
return $this->render('index');
}
我有不同类型的库存,每个库存有多个账单。我正在尝试创建一个报告,获取特定日期范围($from,$to)之间的账单数量,按库存类型对它们进行分组,然后总结每种类型的值并显示该类型的那些值。 =12=]
这是我的查看代码:
if( isset($show_results) )
{
print(GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
[
'attribute'=>'teis_bill_id',
'value'=>'teis_bill_id',
],
'inventory.teis_inventory_type',
'teis_bill_pieces',
'teis_bill_override_cbm',
'teis_bill_sale_price',
'teis_bill_profit',
['class' => 'yii\grid\ActionColumn'],
],
]));
}
我已经包含了视图的代码,因为我不知道如何在得到它后显示它!
如有任何帮助,我们将不胜感激。
谢谢!
我认为问题与 sum('teis_bill_override_cbm')
字段的别名有关
尝试 select 您的字段并使用 sum('teis_bill_override_cbm') as teis_bill_override_cbm
求和
$searchModel = new Bill();
$query = $searchModel::find();
$query->select('teis_bill_id, inventory.teis_inventory_type,
sum(teis_bill_override_cbm ) as teis_bill_override_cbm,
teis_bill_pieces, teis_bill_sale_price, teis_bill_profit');
$query->where(['BETWEEN', 'teis_bill_purchase_date', $from, $to]);
// The problem is in the below sum
$query->joinWith('inventory');
$query->groupBy('teis_inventory_id');
//$query->sum('teis_bill_override_cbm'); already calculated
$query->all();
这里的问题是$query->all()
returns结果是一个数组,但是结果没有保存在任何变量中。
请尝试 $var = $query->all();
,以便保存执行语句的结果。
我正在尝试计算 groupby 查询的总和并将该值发送到 yii2 中的视图。我当前的代码获取并显示了正确的分组,但总和不起作用。
控制器代码如下:
public function actionIndex()
{
if( Yii::$app->request->post('search') )
{
$from = Yii::$app->request->post('from');
$to = Yii::$app->request->post('to');
switch( Yii::$app->request->post('activity') )
{
case 'bills':
$searchModel = new Bill();
$query = $searchModel::find();
$query->where(['BETWEEN', 'teis_bill_purchase_date', $from, $to]);
// The problem is in the below sum
$query->joinWith('inventory');
$query->groupBy('teis_inventory_id');
$query->sum('teis_bill_override_cbm');
$query->all();
$dataProvider = new ActiveDataProvider([
'query' => $query,
]);
return $this->render('index', [
'searchModel' => $searchModel,
'dataProvider' => $dataProvider,
'show_results' => 1
]);
break;
}
}
return $this->render('index');
}
我有不同类型的库存,每个库存有多个账单。我正在尝试创建一个报告,获取特定日期范围($from,$to)之间的账单数量,按库存类型对它们进行分组,然后总结每种类型的值并显示该类型的那些值。 =12=]
这是我的查看代码:
if( isset($show_results) )
{
print(GridView::widget([
'dataProvider' => $dataProvider,
'filterModel' => $searchModel,
'columns' => [
['class' => 'yii\grid\SerialColumn'],
[
'attribute'=>'teis_bill_id',
'value'=>'teis_bill_id',
],
'inventory.teis_inventory_type',
'teis_bill_pieces',
'teis_bill_override_cbm',
'teis_bill_sale_price',
'teis_bill_profit',
['class' => 'yii\grid\ActionColumn'],
],
]));
}
我已经包含了视图的代码,因为我不知道如何在得到它后显示它!
如有任何帮助,我们将不胜感激。 谢谢!
我认为问题与 sum('teis_bill_override_cbm')
字段的别名有关
尝试 select 您的字段并使用 sum('teis_bill_override_cbm') as teis_bill_override_cbm
求和$searchModel = new Bill();
$query = $searchModel::find();
$query->select('teis_bill_id, inventory.teis_inventory_type,
sum(teis_bill_override_cbm ) as teis_bill_override_cbm,
teis_bill_pieces, teis_bill_sale_price, teis_bill_profit');
$query->where(['BETWEEN', 'teis_bill_purchase_date', $from, $to]);
// The problem is in the below sum
$query->joinWith('inventory');
$query->groupBy('teis_inventory_id');
//$query->sum('teis_bill_override_cbm'); already calculated
$query->all();
这里的问题是$query->all()
returns结果是一个数组,但是结果没有保存在任何变量中。
请尝试 $var = $query->all();
,以便保存执行语句的结果。