查询语句优化问题

都市夜猫 2013-02-27 03:59:22
表 ur_logs_dl 和 ur_logs_done 的记录数都相当大,千万记录以上
请问下面那条语句查询效率更高?

select * from [ur_logs_dl]
where [coltdid] = 'XXXXX'
and not exists (select * from [ur_logs_done] where fid = [ur_logs_dl].id)

select * from [ur_logs_dl]
where [coltdid] = 'XXXXX'
and id not in (select fid from [ur_logs_done])
...全文
268 5 打赏 收藏 转发到动态 举报
写回复
用AI写文章
5 条回复
切换为时间正序
请发表友善的回复…
发表回复
昵称被占用了 2013-02-27
  • 打赏
  • 举报
回复
第一个语句效率高 除了两表id字段主键是需要的外,[ur_logs_dl]的[coltdid]字段必须有索引
都市夜猫 2013-02-27
  • 打赏
  • 举报
回复
这台机上没装 sql server,无法得到执行计划 还没定是否需要建索引,速度不可接受时再建,id 字段为主键
-Tracy-McGrady- 2013-02-27
  • 打赏
  • 举报
回复
楼主还是一坨版主?
發糞塗牆 2013-02-27
  • 打赏
  • 举报
回复
1、执行计划贴出来; 2、索引情况贴出来。
-Tracy-McGrady- 2013-02-27
  • 打赏
  • 举报
回复
上面那个高。

34,590

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server相关内容讨论专区
社区管理员
  • 基础类社区
  • 二月十六
  • 卖水果的net
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧