Here is my code below. It appears that the two files join but only the Column headings show from the second dataset. I'm also attaching a screen shot of the "joined" file. I'm using SAS 9.4. Thanks
proc sql undo_policy = none;
     create table FinalBharReg as select
     a.*, b.*
     from fundaBETABhar a left join ControlsBhar b
     on a.gvkey= b.gvkey2 and a.datadate= b.datadate2;
quit;
No screenshot was attached.
That usually happens when your join condition is wrong and you have no matches, so everything shows up as missing.
Check the fields you're joining and see if they match exactly or if you need to change something. For example if its a character variable, are they both the same lengths.
Also make sure to check the log.
@manleygurl wrote:
Here is my code below. It appears that the two files join but only the Column headings show from the second dataset. I'm also attaching a screen shot of the "joined" file. I'm using SAS 9.4. Thanks
proc sql undo_policy = none;
create table FinalBharReg as select
a.*, b.*
from fundaBETABhar a left join ControlsBhar b
on a.gvkey= b.gvkey2 and a.datadate= b.datadate2;
quit;
It means that the condition
gvkey= b.gvkey2 and a.datadate= b.datadate2
is never met. If you replace left join by inner join, the output table should be empty.
One of many possible reasons for this would be that the dates have different representations in both tables.
thank you
"Columns headings" meaning columns, or?
If your tables have the same columns names, yes, they will overwrite (since you are using *) - but you should get a notification in the log if that's the case.
It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.
Ready to level-up your skills? Choose your own adventure.
