oracle的子查询出现> ORA-00907: 缺失右括号
原本是在mysql,由于需要做数据迁移,于是在调试的时候碰到了SQL的问题,下面的这个SQL在mysql中可以完美执行,
然后移植到oracle中就报错。
mysql执行效果
SQL语句:
SELECT
m.projectNum,
n.warinnngNum,
k.deviceNum,
l.reportNum
FROM
(
(
SELECT
count( 1 ) AS projectNum
FROM
ENGINEERING_PROJECT a3
LEFT JOIN MONITORING_PROJECT d3 ON a3.ID = d3.ENGINEERING_ID
WHERE
a3.ORG_UNIT_ID = ''
AND d3.ID IS NOT NULL
AND a3.DEL_FLAG = '0'
AND d3.DEL_FLAG = '0'
) m,
(
SELECT
count( 1 ) AS warinnngNum
FROM
ENGINEERING_PROJECT a
LEFT JOIN MONITORING_PROJECT d ON a.ID = d.ENGINEERING_ID
LEFT JOIN WARNING_INFO b ON d.ID = b.PROJECT_ID
WHERE
a.ORG_UNIT_ID = ''
AND b.ID IS NOT NULL
) n,
(
SELECT
count( 1 ) AS deviceNum
FROM
SENSOR c1
WHERE
c1.ORG_UNIT_ID = ''
AND c1.DEL_FLAG = '0'
AND c1.ID IS NOT NULL
) k,
(
SELECT
count( 1 ) AS reportNum
FROM
ENGINEERING_PROJECT a2
LEFT JOIN AHT_REPORT b2 ON a2.ID = b2.ENGINEERING_ID
WHERE
a2.ORG_UNIT_ID = ''
AND b2.DEL_FLAG = '0'
AND b2.ID IS NOT NULL
) l
)
然后在oracle执行
然后发现在oracle 11g当中 这个多个子查询不需要括号
于是去掉最外部一组括号,完美执行