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当中 这个多个子查询不需要括号

于是去掉最外部一组括号,完美执行 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值