Good morning @Renoux @Kurt_Bremser
I have understood why the code works. Pratically, I read a dataset where the column E_T99_X0010 doesn't exist.
However, I would find a way to insert new values ( came out from a join) in a column altready existing in one step (I know that I can do this with two steps).
The following code is another new column to create but the scope is the same:
proc sql;
create table AG_E_DM_T031_INDOTHX_PROVA as
select a.*,
case when E_T031_C0010=E_DOMINIO then E_DESCRIZIONE
else E_T031_C0010 end as E_T031_X0010
from mis2dm.AG_E_DM_T031_INDOTHX a
left join DOMINI_LDR_FIX b
on a.E_PU_08910=b.E_PU_08910 and a.E_T031_C0010=b.E_DOMINIO ;
quit;
this is the log
1 ;*';*";*/;quit;run;
2 OPTIONS PAGENO=MIN;
3 %LET _CLIENTTASKLABEL='Aggiunta campi con sigla X';
4 %LET _CLIENTPROCESSFLOWNAME='Flusso dei processi';
5 %LET _CLIENTPROJECTPATH='C:\Users\AntonioCiccaglione\Desktop\Iccrea\Implementazione colonne X e aggiunta descrizione.egp'
5 ! ;
6 %LET _CLIENTPROJECTPATHHOST='LAPTOP-5ML4ES7K';
7 %LET _CLIENTPROJECTNAME='Implementazione colonne X e aggiunta descrizione.egp';
8 %LET _SASPROGRAMFILE='';
9 %LET _SASPROGRAMFILEHOST='';
10
11 ODS _ALL_ CLOSE;
12 OPTIONS DEV=SVG;
13 GOPTIONS XPIXELS=0 YPIXELS=0;
14 %macro HTML5AccessibleGraphSupported;
15 %if %_SAS_VERCOMP_FV(9,4,4, 0,0,0) >= 0 %then ACCESSIBLE_GRAPH;
16 %mend;
17 FILENAME EGHTML TEMP;
18 ODS HTML5(ID=EGHTML) FILE=EGHTML
19 OPTIONS(BITMAP_MODE='INLINE')
20 %HTML5AccessibleGraphSupported
21 ENCODING='utf-8'
22 STYLE=HtmlBlue
23 NOGTITLE
24 NOGFOOTNOTE
25 GPATH=&sasworklocation
26 ;
NOTE: Writing HTML5(EGHTML) Body file: EGHTML
27
28 proc sql;
29 create table AG_E_DM_T031_INDOTHX_PROVA as
30 select a.*,
31 case when E_T031_C0010=E_DOMINIO then E_DESCRIZIONE
32 else E_T031_C0010 end as E_T031_X0010
33 from mis2dm.AG_E_DM_T031_INDOTHX a
34 left join DOMINI_LDR_FIX b
35 on a.E_PU_08910=b.E_PU_08910 and a.E_T031_C0010=b.E_DOMINIO ;
WARNING: Variable E_T031_X0010 already exists on file WORK.AG_E_DM_T031_INDOTHX_PROVA.
NOTE: Table WORK.AG_E_DM_T031_INDOTHX_PROVA created, with 34 rows and 59 columns.
36 quit;
NOTE: PROCEDURE SQL used (Total process time):
real time 0.01 seconds
user cpu time 0.02 seconds
system cpu time 0.01 seconds
memory 14998.01k
OS Memory 34392.00k
Timestamp 20/07/2022 07:32:52 m.
Step Count 13 Switch Count 2
Page Faults 0
Page Reclaims 1051
Page Swaps 0
Voluntary Context Switches 139
Involuntary Context Switches 5
Block Input Operations 0
Block Output Operations 2088
Question: is there a way to update a column already existing in a table through join?
Many Thanks
I see I have to repeat myself.
Do NOT (as in NOT) use the asterisk. The asterisk includes the existing variable and prevents the creation of a new one with the same name.
Do this instead:
proc sql;
create table AG_E_DM_T031_INDOTHX_PROVA as
select
/* list of all variables except E_T031_X0010 */
,coalesce(b.E_DESCRIZIONE,a.E_T031_C0010) as E_T031_X0010
from mis2dm.AG_E_DM_T031_INDOTHX a
left join DOMINI_LDR_FIX b
on a.E_PU_08910 = b.E_PU_08910 and a.E_T031_C0010 = b.E_DOMINIO
;
quit;
The second part of the ON clause makes the CASE unnecessary, but you still must make sure that the original value prevails if no match is found, therefore the COALESCE function. If no match is found, E_DESCRIZIONE is missing and the original value is kept.
Big hint for the future: refrain from using the asterisk. Only use it if you do not create any new variables, or can be positively sure that the new variable(s) do not exist already.
It's finally time to hack! Remember to visit the SAS Hacker's Hub regularly for news and updates.
Learn how use the CAT functions in SAS to join values from multiple variables into a single value.
Find more tutorials on the SAS Users YouTube channel.
Ready to level-up your skills? Choose your own adventure.