sql语句优化之用EXISTS替代IN、用NOT EXISTS替代NOT IN的语句
在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下,使用EXISTS(或NOTEXISTS)通常将提高查询的效率。在子查询中,NOTIN子句将执行一个内部的排序和合并。无论在哪种情况下,NOTIN都是最低效的(因为它对子查询中的表执行了一个全表遍历)。为了避免使用NOTIN,我们可以把它改写成外连接(OuterJoins)或NOTEXISTS。 如 我要查询Sendorder表中的冗余数据(没有和reg_person或worksite相连的数据) sql="selectSendorder.id,Sendorder.reads,Sendorder.addtimefromSendorderwhereSendorder.person_idnotin(selectuser_idfromreg_person)orSendorder.worksite_idnotin(selectidfromworksite)orderbySendorder.addtimedesc" (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |