BookmarkSubscribeRSS Feed
jplarios
Quartz | Level 8
HI:
I am wandering why would the first take a lot longer then the second query in proc sql , the difference is noted in NOTE DIFFERENCE comment.


:
/*Query 1 */
proc sql;

select a.id,
b.name

from transactions as a ,
person as b
where
a.id = b.id
and
b.seq = (
select max(sub.seq)
from person as sub
where b.id = sub.id /*NOTE DIFFERENCE*/
)
quit;


/*Query 2 */
proc sql;

select a.id,
b.name

from transactions as a ,
person as b
where
a.id = b.id
and
b.seq = (
select max(sub.seq)
from person as sub
where a.id = sub.id /*NOTE DIFFERENCE*/

)
quit;
2 REPLIES 2
Doc_Duke
Rhodochrosite | Level 12
There are a lot of POSSIBLE reasons that are data dependent. Without knowing the data, we are shooting in the dark. Possible reasons include:
-- size of data set a vs b.
-- indexing on a vs b.
-- location of a vs b (e.g. SAS dataset or Oracle database).
-- data set type (view vs dataset)

Doc Muhlbaier
Duke
ballardw
Super User
As a minor addition to Docs comment on location: network drive vs local if your network runs like mine.

hackathon24-white-horiz.png

2025 SAS Hackathon: There is still time!

Good news: We've extended SAS Hackathon registration until Sept. 12, so you still have time to be part of our biggest event yet – our five-year anniversary!

Register Now

What is Bayesian Analysis?

Learn the difference between classical and Bayesian statistical approaches and see a few PROC examples to perform Bayesian analysis in this video.

Find more tutorials on the SAS Users YouTube channel.

SAS Training: Just a Click Away

 Ready to level-up your skills? Choose your own adventure.

Browse our catalog!

Discussion stats
  • 2 replies
  • 1126 views
  • 0 likes
  • 3 in conversation