全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
2702 8
2013-03-04
各位大神:
    小弟请教一题,
    proc sql;
          create table temp as
          select id,
                   sum(price) as income
         from a
         where  id in (select id from b)
         quit
;
    感觉这样做总是很慢,即使B表中的记录条数很少,请问是怎么回事?
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2013-3-4 10:02:32
子查询语句比JOIN低效。

proc sql;
          create table temp as
          select id, sum(price) as income
          from b left join a on
          b.id=a.id;
quit;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-3-4 12:04:09
ls正解
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-3-4 13:20:22
感谢webgu的解答!再追一下,一般子查询和JOIN的用途一样不,是不是涉及到子查询的都可以用JOIN替代?
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-3-4 16:47:37
我还没有涉及过大数据量的操作,没有体会到这两种方法的差别。只是哪个用来顺手就用哪个了。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-3-4 20:00:34
嗯,谢谢楼主!
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群