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

I am trying to update multiple columns using SQL update. It gives me error at highlighted and undelined area (at the end of the where clause)

 

proc sql;
update want as a
set CntA = (select coalesce(sum(A),0)
, CntB = (select coalesce(sum(B),0)
, CntC = (select coalesce(sum(C),0)
, CntD = (select coalesce(sum(D),0)
from have where (a.Originator = Originator) and (year) between (a.year)-8 and (a.failureyear)-1;
quit;

 

 

1 ACCEPTED SOLUTION

Accepted Solutions
PGStats
Opal | Level 21

Unfortunately, the SQL UPDATE syntax is quite rigid. You must repeat the subquery on each assignment

 

proc sql;
update want as a 
set 
  CntA = (select coalesce(sum(A),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1)
, CntB = (select coalesce(sum(B),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1)
, CntC = (select coalesce(sum(C),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1)
, CntD = (select coalesce(sum(D),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1);
quit;

(untested)

PG

View solution in original post

1 REPLY 1
PGStats
Opal | Level 21

Unfortunately, the SQL UPDATE syntax is quite rigid. You must repeat the subquery on each assignment

 

proc sql;
update want as a 
set 
  CntA = (select coalesce(sum(A),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1)
, CntB = (select coalesce(sum(B),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1)
, CntC = (select coalesce(sum(C),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1)
, CntD = (select coalesce(sum(D),0) 
	from have 
	where (a.Originator = Originator) and year between (a.year)-8 and (a.failureyear)-1);
quit;

(untested)

PG

SAS Innovate 2025: Register Now

Registration is now open for SAS Innovate 2025 , our biggest and most exciting global event of the year! Join us in Orlando, FL, May 6-9.
Sign up by Dec. 31 to get the 2024 rate of 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
  • 1 reply
  • 19600 views
  • 0 likes
  • 2 in conversation