群是如何在甲骨文中使用的?我已经尝试了几个小时了,我仍然不知道为什么我会犯这个错误。原始sql是用普适语言编写的。我正试着把它转化为神谕。
我得到的错误是:
ORA-00904: "SHA": invalid identifier
00904. 00000 - "%s: invalid identifier"这是我的疑问:
SELECT
CASE
WHEN (pch + pk) > 999999999
THEN 'j-9999 and OVER'
WHEN (pch + pk) >= 1000000
THEN 'i-1, < 999'
END AS SHA,
SUM(pch + pk) AS TOTALSHA
FROM hold, pos
WHERE hold.ho = pos.pho AND (pch + pk) > 0
GROUP BY SHA;发布于 2015-03-18 18:43:29
不能按输出值分组。重复这个表达式:
SELECT
CASE
WHEN (pch + pk) > 999999999
THEN 'j-9999 and OVER'
WHEN (pch + pk) >= 1000000
THEN 'i-1, < 999'
END AS SHA,
SUM(pch + pk) AS TOTALSHA
FROM hold, pos
WHERE hold.ho = pos.pho AND (pch + pk) > 0
GROUP BY CASE
WHEN (pch + pk) > 999999999
THEN 'j-9999 and OVER'
WHEN (pch + pk) >= 1000000
THEN 'i-1, < 999'
END;或者,计算子查询中的值并将结果分组:
SELECT
SHA,
SUM(pch + pk) AS TOTALSHA
FROM (
SELECT
CASE
WHEN (pch + pk) > 999999999
THEN 'j-9999 and OVER'
WHEN (pch + pk) >= 1000000
THEN 'i-1, < 999'
END AS SHA,
pch,
pk
FROM hold, pos
WHERE hold.ho = pos.pho AND (pch + pk) > 0
) AS X
GROUP BY SHAhttps://stackoverflow.com/questions/29130176
复制相似问题