BookmarkSubscribeRSS Feed
☑ This topic is solved. Need further help from the community? Please sign in and ask a new question.
ender111
Obsidian | Level 7

I am trying to process a generic data set from SAS using a data plan in Visual Analytics to avoid excess data sets in our libraries.  I know there is a data step code option in the data plan builder, and I can get a data step to work, but whenever I use a proc sql or proc sort statement it fails.  

I can't imagine they would build the functionality of a data step into this interface without also allowing sorts and proc sql blocks... only using data steps will not get me far. 

 

So am I incorrect?  Can you use PROC SORT and PROC SQL with a certain syntax that I am just missing the trick?  I have used brackets, no brackets, and only the documented dataset aliases.  

1 ACCEPTED SOLUTION

Accepted Solutions
Stu_SAS
SAS Employee

Hey @ender111! Can you post the error messages you are getting? If you are processing a dataset in a CASLIB that also outputs to a CASLIB, proc sort will not work as expected (unless you are deduping). CAS does not need data to be sorted in order to work with it like traditional SAS datasets do. The main reason for this is (1) due to the architecture of CAS, and (2) the parallel processing capabilities of CAS. CAS will perform sorts in the background as you ask for by-group processing. You can, however, store data in a sorted order within CAS if you partition it to reduce the amount of background sorting and data transfer that is done, but it is not necessary and is usually done for performance reasons. This is helpful if you're regularly accessing data in a sorted format (e.g. transactional by time).

 

To run SQL in CAS, you must use FEDSQL. PROC SQL does not run in CAS, but PROC FEDSQL does. FEDSQL is very similar to SQL, but is based on ANSI:1999 SQL. 

View solution in original post

2 REPLIES 2
Stu_SAS
SAS Employee

Hey @ender111! Can you post the error messages you are getting? If you are processing a dataset in a CASLIB that also outputs to a CASLIB, proc sort will not work as expected (unless you are deduping). CAS does not need data to be sorted in order to work with it like traditional SAS datasets do. The main reason for this is (1) due to the architecture of CAS, and (2) the parallel processing capabilities of CAS. CAS will perform sorts in the background as you ask for by-group processing. You can, however, store data in a sorted order within CAS if you partition it to reduce the amount of background sorting and data transfer that is done, but it is not necessary and is usually done for performance reasons. This is helpful if you're regularly accessing data in a sorted format (e.g. transactional by time).

 

To run SQL in CAS, you must use FEDSQL. PROC SQL does not run in CAS, but PROC FEDSQL does. FEDSQL is very similar to SQL, but is based on ANSI:1999 SQL. 

ender111
Obsidian | Level 7

Thanks Stu!  I didn't realize FEDSQL was the only option in CASL, which is unfortunate.  As for the sorting, I performed the same in data step, but included the deduping in the same step.  So, although it's not sorted the correct entries are removed and I resort it on the visualization side.  

hackathon24-white-horiz.png

The 2025 SAS Hackathon has begun!

It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.

Latest Updates

Tips for filtering data sources in SAS Visual Analytics

See how to use one filter for multiple data sources by mapping your data from SAS’ Alexandria McCall.

Find more tutorials on the SAS Users YouTube channel.

Discussion stats
  • 2 replies
  • 1090 views
  • 0 likes
  • 2 in conversation