如何不使用exists 或in,将一表作为另一表的统计条件进行统计.

lbd8848 2006-09-11 11:07:39
表A与表B有字段关联,通过表a中是否存在与表B关联的条件统计表B的数据.
现在使用的语句:
select count(*) from a where .... and exists (select * from b where zd1=a.zd1 and zd2=a.zd2)
使用以上语句,由于二表的记录太多,严重影响运行速度,不使用诸如exists 或in,有什么好的方法代替更好,请指点!
...全文
285 2 打赏 收藏 转发到动态 举报
写回复
用AI写文章
2 条回复
切换为时间正序
请发表友善的回复…
发表回复
wiler 2006-09-11
  • 打赏
  • 举报
回复
估计你的B表有重复记录
SELECT COUNT(distinct A.ID1) FROM A,B WHERE A.ID1=B.ID1 AND A.ID2=B.ID2
wangzk0206 2006-09-11
  • 打赏
  • 举报
回复
SELECT COUNT(*) FROM A,B WHERE A.ID1=B.ID1 AND A.ID2=B.ID2

17,377

社区成员

发帖
与我相关
我的任务
社区描述
Oracle 基础和管理
社区管理员
  • 基础和管理社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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