sql中in和exists的区别效率问题 转
1个回答
展开全部
回答你的问题是比较费神的
要分不同情况来看待in和exists的效率。
1、A表与B表是一对多的关系(不考虑索引的情况),使用exists语句在查询时效率明显高
2、A表与B表是一对一的时候(不考虑索引的情况),使用exists语句和In语句查询时效率一样高
3、A表与B表是多对多的关系(不考虑索引的情况),使用联接方式(inner join、left join、right join等)效率会更高一些,但不绝对,有时候还要看你想要检索的内容在表里的存放位置,分情况对待。在SQL中没有那个定式适用于所有查询。
若是非要给出这两个哪个更好一些,个人感觉exists会好一些
要分不同情况来看待in和exists的效率。
1、A表与B表是一对多的关系(不考虑索引的情况),使用exists语句在查询时效率明显高
2、A表与B表是一对一的时候(不考虑索引的情况),使用exists语句和In语句查询时效率一样高
3、A表与B表是多对多的关系(不考虑索引的情况),使用联接方式(inner join、left join、right join等)效率会更高一些,但不绝对,有时候还要看你想要检索的内容在表里的存放位置,分情况对待。在SQL中没有那个定式适用于所有查询。
若是非要给出这两个哪个更好一些,个人感觉exists会好一些
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询