join 效率问题。我要比较2张表里面的某个字段比如:cartonID,A表有一列,B表有1列。当然要完全配对才可以。数据表数据在500w上下。

naturalth 2007-11-20 10:17:10
--DIFFERENCE(aa.cartoonid,bb.carton_id)
declare @container_number varchar(20)
set @container_number='HJCU1409491'

--left join 看Nike_factory有的carton 是不是全部在Tbl_BENIKE2_STUFFING有
select * from(select a.so,c.cartoonid from dbo.Nike_factory a,Nike_factory_line b,Nike_factory_cartoon c where b.facid=a.id and b.id=c.lineid and b.container=@container_number and b.tag='P' ) aa left join
(select carton_id from Tbl_BENIKE2_STUFFING where container_number=@container_number and status='P') bb on aa.cartoonid=bb.carton_id;
--right join 看Tbl_BENIKE2_STUFFING 有的是不是全部在Nike_factory里面


select carton_id,cartoonid from(select c.cartoonid from dbo.Nike_factory a,Nike_factory_line b,Nike_factory_cartoon c where b.facid=a.id and b.id=c.lineid and b.container=@container_number and b.tag='P' ) aa right join
(select carton_id,shipping_order from Tbl_BENIKE2_STUFFING where container_number=@container_number and status='P') bb on aa.cartoonid=bb.carton_id

我做分析计划。发现left耗大概4%的资源这个还不是很慢。
我测试结果3s能执行完成这个批处理。
请大家看看。这样是否妥当。谢谢
...全文
243 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
naturalth 2007-11-23
  • 打赏
  • 举报
回复
谢谢。其实我是我并需要去除。我取出来后在在App里面处理。
因为我们系统禁止使用proc
我需要把配对和不配对的打印出来。所以到这些已经够了。
自然使用proc效率也会提升不少。
naturalth 2007-11-21
  • 打赏
  • 举报
回复
谢谢。这个是写法的却可以改进。
我的a和b表数据没有哪个数据大于哪个。
可能有a表比b表多,或者b比a多。
我发现full join没有完全能把结果全部找出来。

当然我是做的windows服务程序。
我系统需要统计这些不正常数据所占比例。
我把上面结果读到内存再做处理。
中国风 2007-11-21
  • 打赏
  • 举报
回复
合并为一个:

select
aa.*,bb.*
from
(select
a.so,c.cartoonid
from
dbo.Nike_factory a
join
Nike_factory_line b on b.facid=a.id and b.container=@container_number and b.tag='P'
join
Nike_factory_cartoon c on b.id=c.lineid )aa
full join
(select carton_id,shipping_order
from Tbl_BENIKE2_STUFFING
where container_number=@container_number and status= 'P ')bb on aa.cartoonid=bb.carton_id
where
nullif(aa.cartoonid,bb.carton_id) is not null
中国风 2007-11-21
  • 打赏
  • 举报
回复
nullif(aa.cartoonid,bb.carton_id) is not null 去除这两列相同的值,相同时就null

22,209

社区成员

发帖
与我相关
我的任务
社区描述
MS-SQL Server 疑难问题
社区管理员
  • 疑难问题社区
  • 尘觉
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

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