首页 > 解决方案 > 3706 语法错误:预期介于整数和 ')' 之间

问题描述

我正在努力找出问题所在,我的部分代码看起来像这样

(sel no_2, sum(L) from (
                sel no_2, colB, count(distinct(colC))
                from dbA.tblP as p
                    join dbB.tblI as i on p.id = i.id and p.no = i.no
                    join dbB.tblT as t on i.no_2 = t.no_2
                    join dbA.mp_tblA as a on t.no_2 = a.no_2) l 
                    ) as l
group by 1) as l        

Teradata 点与其中的 group by 1) 一致。我应该在“1”和“)”括号之间放什么?有什么办法可以解决吗?

标签: sqldatabasegroup-bysubqueryteradata

解决方案


看起来你有一个额外) l的东西导致语法错误。尝试这个:

SELECT no_2, SUM(L) 
FROM (
  SELECT no_2, colB, COUNT(DISTINCT colC) AS no_colC
  FROM dbA.tblP AS p
  INNER JOIN dbB.tblI AS i ON p.id = i.id AND p.no = i.no
  INNER JOIN dbB.tblT AS t ON i.no_2 = t.no_2
  INNER JOIN dbA.mp_tblA AS a ON t.no_2 = a.no_2
) AS l
GROUP BY 1

除了评论之外,还有一些关于可读性的建议:

  • 使用SELECT而不是SEL
  • 指定INNER JOIN而不是JOIN
  • 如果你打算使用count(distinct(colC))给它一个别名,比如no_colC

另外,您引用的“L”值是SUM(L)多少?除非您在子选择中包含该字段,否则查询不会按原样工作。


推荐阅读