这是我的陈述,我正在尝试做的是获得每个订单的每个用户的平均金额,遇到问题而不知道如何修复它, 感谢所有帮助
SELECT usuarios.email, AVG(pedidos_onlines.total),
CASE WHEN p.nombre like '%colombia%' and AVG(pedidos_onlines.total) <34873 then 'A'
WHEN p.nombre like '%colombia%' and AVG(pedidos_onlines.total) >= 52309 then 'B'
ELSE 'C'
end as SegmentColombia,
CASE WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) <41 then 'A'
WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) >= 62 then 'B'
ELSE 'C'
end as SegementPeru
CASE WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) <13 then 'A'
WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) >= 19 then 'B'
ELSE 'C'
end as SEGMENT Ecudador
FROM pedidos_onlines
LEFT JOIN usuarios ON usuarios.id = pedidos_onlines.usuario_id
LEFT JOIN ciudades as c on c.id = pedidos_onlines.ciudad_id
LEFT JOIN paises as p on p.id = c.pais_id
WHERE usuarios.email IS NOT NULL
GROUP BY usuarios.email, p.nombre
错误消息:
您的SQL语法有错误;检查手册 对应于您的MySQL服务器版本,以便使用正确的语法 附近'CASE WHEN p.nombre like'%ecuador%'和 AVG(pedidos_onlines.total)&lt; 13然后在第10行'A''
答案 0 :(得分:0)
你在第二个案件结束时错过了一个逗号:
CASE WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) <41 then 'A'
WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) >= 62 then 'B'
ELSE 'C'
end as SegementPeru
需要:
CASE WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) <41 then 'A'
WHEN p.nombre like '%peru%' and AVG(pedidos_onlines.total) >= 62 then 'B'
ELSE 'C'
end as SegementPeru,
编辑:
另外,正如第二个错误所指出的那样:
SEGMENT Ecudador
需要
`SEGMENT Ecudador`
或者你可以移除空间。
答案 1 :(得分:0)
它离你需要的距离不远。
SELECT u.email, AVG(po.total),
CASE WHEN p.nombre like '%colombia%' and AVG(po.total) <34873 then 'A'
WHEN p.nombre like '%colombia%' and AVG(po.total) >= 52309 then 'B'
ELSE 'C'
end as SegmentColombia,
CASE WHEN p.nombre like '%peru%' and AVG(po.total) <41 then 'A'
WHEN p.nombre like '%peru%' and AVG(po.total) >= 62 then 'B'
ELSE 'C'
end as SegementPeru,
CASE WHEN p.nombre like '%peru%' and AVG(po.total) <13 then 'A'
WHEN p.nombre like '%peru%' and AVG(po.total) >= 19 then 'B'
ELSE 'C'
end as `SEGMENT Ecudador`
FROM pedidos_onlines as po
LEFT JOIN usuarios as u ON u.id = po.usuario_id
LEFT JOIN ciudades as c on c.id = po.ciudad_id
LEFT JOIN paises as p on p.id = c.pais_id
WHERE u.email IS NOT NULL
GROUP BY u.email, p.nombre,
CASE WHEN p.nombre like '%colombia%' and AVG(po.total) <34873 then 'A'
WHEN p.nombre like '%colombia%' and AVG(po.total) >= 52309 then 'B'
ELSE 'C'
end,
CASE WHEN p.nombre like '%peru%' and AVG(po.total) <41 then 'A'
WHEN p.nombre like '%peru%' and AVG(po.total) >= 62 then 'B'
ELSE 'C'
end,
CASE WHEN p.nombre like '%peru%' and AVG(po.total) <13 then 'A'
WHEN p.nombre like '%peru%' and AVG(po.total) >= 19 then 'B'
ELSE 'C'
end