SQL语句中exists和in的区别--摘录自https://www.cnblogs.com/emilyyoucan/p/7833769.html
当B表比A表数据大时,适合使用exists(),因为它没有那么遍历操作,只需要执行一次查询就行。如果A表有10000条记录,B表有1000000条记录,那么exists()会执行10000次去判断A表中的id是否与B表中的id相等。如果A表有10000条记录,B表有100000000条记录,那么exist()还是执行10000次,因为它只执行A.length次,可见B表数据越大,越适合exists()发挥效果。再如A表有10000条记录,B表有100条记录,那么exists()还是执行10000次,还不如使用in()遍历10000*1000次,因为in()是在内在里遍历比较。而exists()需要查询数据库。查询数据库所消耗的性能更高,而内存比较快。
结果:exists()适合B表比A表数据大的情况。