V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
ge2009
V2EX  ›  Oracle

奇怪同样的 SQL 语句在 11.2.0.3 下无法执行,在 11.1.0.6 却可以,有没高手可以看下

  •  
  •   ge2009 · 2015-12-17 11:13:29 +08:00 · 2220 次点击
    这是一个创建于 3271 天前的主题,其中的信息可能已经有所发展或是发生改变。

    SQL 语句:
    SELECT patient_id,
    patient_name,
    other_patient_id,
    other_patient_name,
    english_patient_name,
    patient_id_issuer,
    patient_sex,
    patient_birth_date,
    patient_birth_time,
    count(*) as study_count,
    sum(series_count) as series_count,
    sum(instance_count) as instance_count,
    NULL
    FROM sv_study_patient_id s
    WHERE merge_key IS NULL
    AND hide_code IS NULL
    AND instance_count > 0
    AND rownum < 1000
    GROUP BY patient_id,
    patient_id_issuer,
    patient_name,
    other_patient_id,
    other_patient_name,
    english_patient_name,
    patient_sex,
    patient_birth_dttm,
    merge_key,
    hide_code

    在 11.2.0.3 下报 ORA-00979 错误,
    http://ww3.sinaimg.cn/large/42ae781fgw1ez2hfuc8c0j21kw0wmqk4.jpg

    可在 11.1.0.6 下却可以执行成功
    http://ww3.sinaimg.cn/large/42ae781fgw1ez2he6ruu2j20wz0kitfv.jpg

    请解

    3 条回复    2015-12-17 12:07:45 +08:00
    mringg
        1
    mringg  
       2015-12-17 11:33:39 +08:00 via Android   ❤️ 1
    语句貌似就有问题, select 非聚集的列必须用 group by 分组
    mringg
        2
    mringg  
       2015-12-17 11:34:34 +08:00 via Android
    还有个不是问题的问题,能不能 select 和 group by 后面的列顺序保持一直
    ge2009
        3
    ge2009  
    OP
       2015-12-17 12:07:45 +08:00
    @mringg 就像你说的我把 patient_birth_date,patient_birth_time 这两列去掉,或者在 Group by 里面加上,好像都可以执行,可能 Oracle 11G 后对 SQL 的解析上是这样了,谢谢!
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2481 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 23ms · UTC 02:37 · PVG 10:37 · LAX 18:37 · JFK 21:37
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.