<?xml version="1.0" encoding="UTF-8"?>
<rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#" xmlns:taxo="http://purl.org/rss/1.0/modules/taxonomy/" version="2.0">
  <channel>
    <title>topic Re: Performing additional calculations in PROC SQL in SAS Programming</title>
    <link>https://communities.sas.com/t5/SAS-Programming/Performing-additional-calculations-in-PROC-SQL/m-p/831543#M328619</link>
    <description>&lt;P&gt;This can be accomplished using SQL in-line views:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
    create table sum_by_totda as
    select a.usubjid
			 ,'DACAPNT' as PARAMCD
/*			 ,a.AVAL as Issued
			 ,Returned
			 ,Dispensed */
			 ,a.aval+Dispensed-Returned as AVAL
		from (
				select usubjid, AVAL
				        		 from sdtm.da  where paramcd ="CAPSEXP"
				) as a
	 	left join 
			  (
				select usubjid, sum(dastresn) as Returned
        		 from sdtm.da  where datestcd ="RETAMT"
			    group by usubjid
				) as b
		on a.usubjid=b.usubjid
	 	left join 
			  (
				select usubjid, sum(dastresn) as Dispensed
        			from sdtm.da  where datestcd ="DISPAMT"
			    	group by usubjid
				) as c
    	on a.usubjid=c.usubjid
	 	;
quit;
&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;However, the calculation for AVAL specified doesn't make any sense to me. Here is what the values look like:&lt;/P&gt;
&lt;DIV class="branch"&gt;
&lt;DIV&gt;
&lt;DIV align="left"&gt;
&lt;TABLE class="table" summary="Procedure SQL: Query Results" frame="box" rules="all" cellspacing="0" cellpadding="5"&gt;
&lt;THEAD&gt;
&lt;TR&gt;
&lt;TH class="r b header" scope="col"&gt;usubjid&lt;/TH&gt;
&lt;TH class="l b header" scope="col"&gt;PARAMCD&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;Issued&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;Returned&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;Dispensed&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;AVAL&lt;/TH&gt;
&lt;/TR&gt;
&lt;/THEAD&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;1&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="r data"&gt;8&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;2&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="r data"&gt;8&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="r data"&gt;8&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;4&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;1&lt;/TD&gt;
&lt;TD class="r data"&gt;6&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;5&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;2&lt;/TD&gt;
&lt;TD class="r data"&gt;7&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I would expect the final calculation to be AVAL-(Dispensed+Returned):&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
    create table sum_by_totda as
    select a.usubjid
			 ,'DACAPNT' as PARAMCD
             ,a.AVAL as Issued&lt;BR /&gt;             ,Returned&lt;BR /&gt;             ,Dispensed&lt;BR /&gt;			 ,a.aval-(Dispensed+Returned) as AVAL
		from (
				select usubjid, AVAL
				        		 from sdtm.da  where paramcd ="CAPSEXP"
				) as a
	 	left join 
			  (
				select usubjid, sum(dastresn) as Returned
        		 from sdtm.da  where datestcd ="RETAMT"
			    group by usubjid
				) as b
		on a.usubjid=b.usubjid
	 	left join 
			  (
				select usubjid, sum(dastresn) as Dispensed
        			from sdtm.da  where datestcd ="DISPAMT"
			    	group by usubjid
				) as c
    	on a.usubjid=c.usubjid
	 	;
quit;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Which yields:&lt;/P&gt;
&lt;DIV class="branch"&gt;
&lt;DIV&gt;
&lt;DIV align="left"&gt;
&lt;TABLE class="table" summary="Procedure SQL: Query Results" frame="box" rules="all" cellspacing="0" cellpadding="5"&gt;
&lt;THEAD&gt;
&lt;TR&gt;
&lt;TH class="r b header" scope="col" width="46.9889px"&gt;usubjid&lt;/TH&gt;
&lt;TH class="l b header" scope="col" width="87.9883px"&gt;PARAMCD&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="42.985px"&gt;Issued&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="57.9915px"&gt;Returned&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="64.9902px"&gt;Dispensed&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="39.9902px"&gt;AVAL&lt;/TH&gt;
&lt;/TR&gt;
&lt;/THEAD&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;1&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;2&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;4&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;1&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;4&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;5&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;</description>
    <pubDate>Fri, 02 Sep 2022 13:18:12 GMT</pubDate>
    <dc:creator>SASJedi</dc:creator>
    <dc:date>2022-09-02T13:18:12Z</dc:date>
    <item>
      <title>Performing additional calculations in PROC SQL</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Performing-additional-calculations-in-PROC-SQL/m-p/831527#M328612</link>
      <description>&lt;P&gt;&lt;SPAN&gt;I have this specification to derive AVAL for parameter code DACAPNT&lt;/SPAN&gt;&lt;/P&gt;
&lt;P&gt;&lt;span class="lia-inline-image-display-wrapper lia-image-align-inline" image-alt="smackerz1988_0-1662118126041.png" style="width: 400px;"&gt;&lt;img src="https://communities.sas.com/t5/image/serverpage/image-id/74943i0F3B52B1BA421864/image-size/medium?v=v2&amp;amp;px=400" role="button" title="smackerz1988_0-1662118126041.png" alt="smackerz1988_0-1662118126041.png" /&gt;&lt;/span&gt;&lt;/P&gt;
&lt;P&gt;&lt;SPAN&gt;For the text highlighted in red this is the code I'm trying to use&lt;/SPAN&gt;&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;*Performing calculations for DACAPNT AVAL *;
proc sql;
    create table sum_by_totda as
    select *
           ,sum(dastresn) as totn            
    from sdtm.da
    where datestcd in ("RETAMT","DISPAMT")
    group by usubjid, datestcd
    ;
quit;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;&lt;SPAN&gt;My question is is there a way to do the calculation within this PROC SQL statement or would this require an additional data step/PROC SQL?&lt;/SPAN&gt;&lt;/P&gt;</description>
      <pubDate>Fri, 02 Sep 2022 11:29:45 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Performing-additional-calculations-in-PROC-SQL/m-p/831527#M328612</guid>
      <dc:creator>smackerz1988</dc:creator>
      <dc:date>2022-09-02T11:29:45Z</dc:date>
    </item>
    <item>
      <title>Re: Performing additional calculations in PROC SQL</title>
      <link>https://communities.sas.com/t5/SAS-Programming/Performing-additional-calculations-in-PROC-SQL/m-p/831543#M328619</link>
      <description>&lt;P&gt;This can be accomplished using SQL in-line views:&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
    create table sum_by_totda as
    select a.usubjid
			 ,'DACAPNT' as PARAMCD
/*			 ,a.AVAL as Issued
			 ,Returned
			 ,Dispensed */
			 ,a.aval+Dispensed-Returned as AVAL
		from (
				select usubjid, AVAL
				        		 from sdtm.da  where paramcd ="CAPSEXP"
				) as a
	 	left join 
			  (
				select usubjid, sum(dastresn) as Returned
        		 from sdtm.da  where datestcd ="RETAMT"
			    group by usubjid
				) as b
		on a.usubjid=b.usubjid
	 	left join 
			  (
				select usubjid, sum(dastresn) as Dispensed
        			from sdtm.da  where datestcd ="DISPAMT"
			    	group by usubjid
				) as c
    	on a.usubjid=c.usubjid
	 	;
quit;
&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;However, the calculation for AVAL specified doesn't make any sense to me. Here is what the values look like:&lt;/P&gt;
&lt;DIV class="branch"&gt;
&lt;DIV&gt;
&lt;DIV align="left"&gt;
&lt;TABLE class="table" summary="Procedure SQL: Query Results" frame="box" rules="all" cellspacing="0" cellpadding="5"&gt;
&lt;THEAD&gt;
&lt;TR&gt;
&lt;TH class="r b header" scope="col"&gt;usubjid&lt;/TH&gt;
&lt;TH class="l b header" scope="col"&gt;PARAMCD&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;Issued&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;Returned&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;Dispensed&lt;/TH&gt;
&lt;TH class="r b header" scope="col"&gt;AVAL&lt;/TH&gt;
&lt;/TR&gt;
&lt;/THEAD&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;1&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="r data"&gt;8&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;2&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="r data"&gt;8&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;3&lt;/TD&gt;
&lt;TD class="r data"&gt;8&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;4&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;1&lt;/TD&gt;
&lt;TD class="r data"&gt;6&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD class="r data"&gt;5&lt;/TD&gt;
&lt;TD class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD class="r data"&gt;20&lt;/TD&gt;
&lt;TD class="r data"&gt;15&lt;/TD&gt;
&lt;TD class="r data"&gt;2&lt;/TD&gt;
&lt;TD class="r data"&gt;7&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;P&gt;&amp;nbsp;&lt;/P&gt;
&lt;P&gt;I would expect the final calculation to be AVAL-(Dispensed+Returned):&lt;/P&gt;
&lt;PRE&gt;&lt;CODE class=" language-sas"&gt;proc sql;
    create table sum_by_totda as
    select a.usubjid
			 ,'DACAPNT' as PARAMCD
             ,a.AVAL as Issued&lt;BR /&gt;             ,Returned&lt;BR /&gt;             ,Dispensed&lt;BR /&gt;			 ,a.aval-(Dispensed+Returned) as AVAL
		from (
				select usubjid, AVAL
				        		 from sdtm.da  where paramcd ="CAPSEXP"
				) as a
	 	left join 
			  (
				select usubjid, sum(dastresn) as Returned
        		 from sdtm.da  where datestcd ="RETAMT"
			    group by usubjid
				) as b
		on a.usubjid=b.usubjid
	 	left join 
			  (
				select usubjid, sum(dastresn) as Dispensed
        			from sdtm.da  where datestcd ="DISPAMT"
			    	group by usubjid
				) as c
    	on a.usubjid=c.usubjid
	 	;
quit;&lt;/CODE&gt;&lt;/PRE&gt;
&lt;P&gt;Which yields:&lt;/P&gt;
&lt;DIV class="branch"&gt;
&lt;DIV&gt;
&lt;DIV align="left"&gt;
&lt;TABLE class="table" summary="Procedure SQL: Query Results" frame="box" rules="all" cellspacing="0" cellpadding="5"&gt;
&lt;THEAD&gt;
&lt;TR&gt;
&lt;TH class="r b header" scope="col" width="46.9889px"&gt;usubjid&lt;/TH&gt;
&lt;TH class="l b header" scope="col" width="87.9883px"&gt;PARAMCD&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="42.985px"&gt;Issued&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="57.9915px"&gt;Returned&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="64.9902px"&gt;Dispensed&lt;/TH&gt;
&lt;TH class="r b header" scope="col" width="39.9902px"&gt;AVAL&lt;/TH&gt;
&lt;/TR&gt;
&lt;/THEAD&gt;
&lt;TBODY&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;1&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;2&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;4&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;1&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;4&lt;/TD&gt;
&lt;/TR&gt;
&lt;TR&gt;
&lt;TD width="46.9889px" class="r data"&gt;5&lt;/TD&gt;
&lt;TD width="87.9883px" class="l data"&gt;DACAPNT&lt;/TD&gt;
&lt;TD width="42.985px" class="r data"&gt;20&lt;/TD&gt;
&lt;TD width="57.9915px" class="r data"&gt;15&lt;/TD&gt;
&lt;TD width="64.9902px" class="r data"&gt;2&lt;/TD&gt;
&lt;TD width="39.9902px" class="r data"&gt;3&lt;/TD&gt;
&lt;/TR&gt;
&lt;/TBODY&gt;
&lt;/TABLE&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;
&lt;/DIV&gt;</description>
      <pubDate>Fri, 02 Sep 2022 13:18:12 GMT</pubDate>
      <guid>https://communities.sas.com/t5/SAS-Programming/Performing-additional-calculations-in-PROC-SQL/m-p/831543#M328619</guid>
      <dc:creator>SASJedi</dc:creator>
      <dc:date>2022-09-02T13:18:12Z</dc:date>
    </item>
  </channel>
</rss>

