gpt4 book ai didi

mysql - 查询,联接和求和问题,返回错误

转载 作者:行者123 更新时间:2023-11-29 15:26:11 25 4
gpt4 key购买 nike

尝试加载数据表时,我的代码有问题,我在Laravel 5.5中使用Yajra数据表

这是我的负载数据表代码

public function getTotalMes(){
return datatables()
->eloquent(Copropietario::select('copropietario')
->join('clientes', 'clientes.id', '=', 'copropietario.cliente_id' )
->join('egresos', 'egresos.cliente_id', '=', 'clientes.id' )
->join('morosos', 'morosos.copropietario_id', '=', 'copropietario.numerodepto' )
->join('medidor', 'medidor.nummedidor', '=', 'copropietario.numerodepto')
->join('calderas', 'calderas.nummedidor', '=', 'copropietario.numerodepto')
->select('copropietario.id',
'copropietario.numerodepto',
'egresos.mescobro',
'egresos.aniocobro',
DB::raw('SUM(egresos.montopago) as suma_total'),
DB::raw('ROUND( (SUM( egresos.montopago ) * ( copropietario.alicuotatotal ))) as gasto_comun'),
DB::raw('ROUND( (((SUM( egresos.montopago ) * ( copropietario.alicuotatotal)))) * (0,05)) as fondo_reserva'),
'copropietario.cliente_id',
'medidor.totalmes as medidor',
'calderas.totalmes as caldera',
'morosos.totalmoroso as deuda_anterior',
'copropietario.alicuotatotal')
->where('egresos.mescobro', '=', 'Octubre')
->where('medidor.fechamedicion', '=', '2019-10-30')
->where('egresos.conceptopago', '<>', 'Caldera Condominio')
->where('egresos.aniocobro', '=', '2019')
->groupBy('copropietario.numerodepto'))
->toJson();
}


并返回此错误

{
"draw": 0,
"recordsTotal": 0,
"recordsFiltered": 0,
"data": [],
"error": "Exception Message:\n\nSQLSTATE[21000]: Cardinality violation: 1241 Operand should contain 1 column(s) (SQL: select count(*) as aggregate from (select `copropietario`.`id`, `copropietario`.`numerodepto`, `egresos`.`mescobro`, `egresos`.`aniocobro`, SUM(egresos.montopago) as suma_total, ROUND( (SUM( egresos.montopago ) * ( copropietario.alicuotatotal ))) as gasto_comun, ROUND( (((SUM( egresos.montopago ) * ( copropietario.alicuotatotal)))) * (0,05)) as fondo_reserva, `copropietario`.`cliente_id`, `medidor`.`totalmes` as `medidor`, `calderas`.`totalmes` as `caldera`, `morosos`.`totalmoroso` as `deuda_anterior`, `copropietario`.`alicuotatotal` from `copropietario` inner join `clientes` on `clientes`.`id` = `copropietario`.`cliente_id` inner join `egresos` on `egresos`.`cliente_id` = `clientes`.`id` inner join `morosos` on `morosos`.`copropietario_id` = `copropietario`.`numerodepto` inner join `medidor` on `medidor`.`nummedidor` = `copropietario`.`numerodepto` inner join `calderas` on `calderas`.`nummedidor` = `copropietario`.`numerodepto` where `egresos`.`mescobro` = Octubre and `medidor`.`fechamedicion` = 2019-10-30 and `egresos`.`conceptopago` <> Caldera Condominio and `egresos`.`aniocobro` = 2019 group by `copropietario`.`numerodepto`) count_row_table)"
}


enter image description here

最佳答案

这里的问题是您正在子查询中进行汇总(求和与舍入)。效果是“ groupby”将不起作用。

这些字段是在子查询中构建的,因此它们实际上并未聚合。

DB::raw('SUM(egresos.montopago) as suma_total'),
DB::raw('ROUND( (SUM( egresos.montopago ) * ( copropietario.alicuotatotal ))) as gasto_comun'),
DB::raw('ROUND( (((SUM( egresos.montopago ) * ( copropietario.alicuotatotal)))) * (0,05)) as fondo_reserva'),


尝试改用orderBy。

您可以像这样雄辩地进行一笔或一轮回合:

 ... ->sum('field');


但我不相信您可以雄辩地进行数学和四舍五入。如果确实需要模型进行汇总,则最好将查询设置为数据库中的视图。

关于mysql - 查询,联接和求和问题,返回错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59075456/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com