发布于 2012-12-03 12:45:34
ORDER BY
,则不需要指定GROUP BY
子句。这从来不是甲骨文鼓励的假设,但甲骨文碰巧对数据进行排序,以便执行GROUP BY
。当在10.2中添加了按操作分类的哈希组时,Oracle不再总是将数据作为分组数据的副产品排序。这导致许多开发人员不得不通过代码来添加ORDER BY
子句。由于不同的优化器设置,其他SQL语句在11g中的执行情况不同(特别是当您从9i中基于规则的优化器中移动时)。发布于 2012-12-03 12:45:03
是在9i中仍然在11g中有效的SQL语句。
在一些情况下,以前有效的SQL语句在以后的版本中变得无效。例如,在Oracle8和9之间,mod
函数用作infix操作符是非法的;也就是说,select 12 mod 3 from dual
在Oracle8中有效,但在Oracle9中无效。(select mod(12,3) from dual
在这两个版本中都有效)
11g中是否有9i中没有的新功能?
是的,当然,但列出它们将超出这个答案的范围。
有效的9i SQL语句与11g中相同的语句之间是否存在行为差异?
有些行为差异可能导致不必要的“影响”。两个例子:
group by
才交付排序结果。(与order by
不完全相同,因为order by
考虑到了特定于语言的顺序,如德语中的“L、M、N、O、、P、Q”,而group by
没有,但对于许多目的来说都足够好)。正因为如此,许多开发人员在order by
子句与group by
子句相同的情况下取消了它。这在Oracle 10g中发生了改变,显然10g使用哈希表而不是排序树进行分组。正因为如此,一些程序以10g的速度提供了与9i不同的结果。(注:在预期有序结果时,省略order by
一直是个坏主意)发布于 2012-12-03 12:06:40
是的,当然。查看引用的第一章,例如01/server.111/b 28286/wnsql.htm#ssnf5
https://stackoverflow.com/questions/13682862
复制相似问题