BookmarkSubscribeRSS Feed
Walternate
Obsidian | Level 7

Hi all,

I am trying to get the sum of a column in a dataset. I tried using both proc means and proc sql, but in both cases, the number of digits in the sum exceeded the length of the variable. I'm not sure how to program a longer length into either of those functions. I tried to do it in proc sql like this:

proc sql;

create table new as

select sum(var) as sum_var length=50 from have;

quit;

The code worked, but ignored my length statement.

Any help is much appreciated.

3 REPLIES 3
haikuobian
Fluorite | Level 6

Not sure I understand your issue, but the length of numeric variable in SAS is 3-8, with 8 as the default. In other words, assign a length greater than 8 will have no effect.

Haikuo

stat_sas
Ammonite | Level 13

Tyr this.

proc sql;

create table new as

select sum(var) as sum_var format=best16. from have;

quit;

jakarman
Barite | Level 11

Check in the documentation the numeric precision chapters.

There are no fixed numbers as all is floating based on internal 8 bytes.

The limit of meaningful digits is about 12

What you are probably looking for is the layout of the result.

That one is the format of the result

---->-- ja karman --<-----

sas-innovate-2026-white.png



April 27 – 30 | Gaylord Texan | Grapevine, Texas

Registration is open

Walk in ready to learn. Walk out ready to deliver. This is the data and AI conference you can't afford to miss.
Register now and lock in 2025 pricing—just $495!

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
  • 3 replies
  • 2255 views
  • 0 likes
  • 4 in conversation