我有一个应用程序创建使用德尔福XE3访问SQLite数据库与Zeos组件。
SQLite中返回3行的select命令:
select p.descricao, pg.valor
from pagamento pg
inner join venda v on pg.origem = 'venda' and v.id_venda = pg.id_origem
left join pagamento_tipo p on pg.id_pagamento_tipo = p.id_pagamento_tipo
where v.data >= '2021-01-19' and v.data <= '2021-01-19'
and v.ra_status_venda in ( 'Finalizado', 'Pedido')

但是当我放入group命令时,信息结果是错误的。
select p.descricao, sum(pg.valor) as valor
from pagamento pg
inner join venda v on pg.origem = 'venda' and v.id_venda = pg.id_origem
left join pagamento_tipo p on pg.id_pagamento_tipo = p.id_pagamento_tipo
where v.data >= '2021-01-19' and v.data <= '2021-01-19'
and v.ra_status_venda in ( 'Finalizado', 'Pedido')
group by descricao

P02不是sum。
而且,如果我对所有行求和,而不使用group by,那么值也是正确的。
select sum(pg.valor) as valor
from pagamento pg
inner join venda v on pg.origem = 'venda' and v.id_venda = pg.id_origem
left join pagamento_tipo p on pg.id_pagamento_tipo = p.id_pagamento_tipo
where v.data >= '2021-01-19' and v.data <= '2021-01-19'
and v.ra_status_venda in ( 'Finalizado', 'Pedido')

PS:在另一个周期中,这个命令的总和是正确的。PS2我使用的是windows的32位动态链接库。
发布于 2021-01-21 21:59:38
使用提示@Shawn和@forpas我解决了这个问题,字段NUMERIC的SQLite类型在运行时select命令中将数字转换为其他类型,如何前两个值是整数,最后一个值是实数,显然我的程序不能识别同一列中的两个不同类型。
为了解决这个问题,我将数据库中的字段类型从数字改为实数。
https://stackoverflow.com/questions/65814104
复制相似问题