在许多基于基础表的查询中,为了满足一个条件,往往需要对另一个表进行联接。在这种情况下,使用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"
程序执行时间:40109.38毫秒

sql="selectSendorder.id,Sendorder.reads,Sendorder.addtimefromSendorderwherenotEXISTS(SELECTidFROMreg_personwherereg_person.user_id=Sendorder.person_id)ornotEXISTS(SELECTidFROMworksitewhereworksite.id=Sendorder.worksite_id)orderbySendorder.addtimedesc"
程序执行时间:8531.25毫秒

很明显使用notEXISTS效率高多了

更多相关文章

  1. Android(安卓)-- Android(安卓)JUint 与 Sqlite
  2. android 当系统存在多个Launcher时,如何设置开机自动进入默认的La
  3. Android(安卓)SQLiteDatabase的使用
  4. android 通话记录次数
  5. Android(安卓)SQLiteDatabase的使用
  6. android实现关键字搜索功能
  7. android之用户定位(一)
  8. 我的android 第14天 - 使用SQLiteDatabase操作SQLite数据库
  9. Android(安卓)编码规范

随机推荐

  1. Android 控制闪光灯
  2. android 之PopupWindow的使用
  3. Android 改变标题栏的背景色
  4. [置顶] Android 百度地图 简单实现--- 美
  5. android 最火的开源项目
  6. android 中定时器的几种用法总结
  7. android > WebView > 布局
  8. virtualbox 安装android设置分辨率(自定
  9. android中MediaPlayer的用法
  10. 原:Android(安卓)获取屏幕高度、标题高度