,按理说应该速度是最快的,where也应该比having快点的,因为它过滤数据后才进行sum,在两个表联接时才用on 的,所以在一个表的时候,就剩下where 跟 having...在多表联接查询时,on比 where 更早起作用。...(15)用EXISTS替代IN、用NOTEXISTS 替代NOT IN: 在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接.在这种情况下,使用EXISTS(或 NOTEXISTS...(21)避免在索引列上使用NOT通常, 我们要避免在索引列上使用 NOT, NOT会产生在和在索引列上使用函数相同的影响.当 ORACLE”遇到”NOT,就会停止使用索引转而执行全表扫描.
(22)避免在索引列上使用计算...如果至少有一个列不为空,则记录存在于索引中.举例:如果唯一性索引建立在表的A 列和B 列上,并且表中存在一条记录的A,B 值为(123,null) , ORACLE将不接受下一条具有相同 A,B 值(123