For most of the cases to optimize the system, we would be in need of the size of the data set, to set some SAS System options like : SORTSIZE, MEMSIZE, REALMEMSIZE etc.
To Calculate size of any SAS dataset:-
For example we want to calculate the size of a data set named as "Calculate" which one is in library named as "Base". Just create the data set that contains one observation and all the number of variables we are in need.
Data base.Calculate;
input name $18. Age 2. Salary 6. ;
Cards;
Uma Shanker Saini 30 300000
;
run;
Proc print;
run;
Now run the CONTENTS procedure with the data set "Calculate".
Proc contents data=Base.Calculate;
Run;
data:image/s3,"s3://crabby-images/3d888/3d88873e6df8360d7e533bfd531d97d9965c6bd9" alt="Calculate"
data:image/s3,"s3://crabby-images/3b0c8/3b0c8ec0813dce5dd748b75f68142fe52a5c263e" alt="Calculate1"
The size of the Calculate data set would depend on the data set page size and the total number of observation in data set.
Formula to calculate :-
Number of data pages = 1 + (floor( observations / Max observation per page))
Size = 256 + ( Data set page size * number of data pages)
* floor is a function which is to round the value
Now as per our example :
Number of data pages = 1 + (floor(1/101))
Data set size = 256 + 4096*1 = 4352
Thus the Calculate data set uses 4,352 bytes of storage space.