mirror of
https://github.com/sasjs/core.git
synced 2025-12-13 23:44:35 +00:00
Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
22f0cb67a5 |
64
all.sas
64
all.sas
@@ -13415,7 +13415,9 @@ run;
|
|||||||
<h4> SAS Macros </h4>
|
<h4> SAS Macros </h4>
|
||||||
@li mf_getuniquefileref.sas
|
@li mf_getuniquefileref.sas
|
||||||
@li mf_getuniquename.sas
|
@li mf_getuniquename.sas
|
||||||
|
@li mf_getvarlist.sas
|
||||||
@li mf_islibds.sas
|
@li mf_islibds.sas
|
||||||
|
@li mf_wordsinstr1butnotstr2.sas
|
||||||
@li mp_abort.sas
|
@li mp_abort.sas
|
||||||
|
|
||||||
<h4> Related Macros </h4>
|
<h4> Related Macros </h4>
|
||||||
@@ -13482,30 +13484,28 @@ create table &ds1 (drop=libref dsn) as
|
|||||||
|
|
||||||
/* extract key values only */
|
/* extract key values only */
|
||||||
%let ds2=%upcase(work.%mf_getuniquename(prefix=mpsd_pks));
|
%let ds2=%upcase(work.%mf_getuniquename(prefix=mpsd_pks));
|
||||||
|
%local keyhash processed;
|
||||||
|
%let keyhash=%upcase(%mf_getuniquename(prefix=mpsdvar_keyhash));
|
||||||
|
%let processed=%upcase(%mf_getuniquename(prefix=mpsdvar_processed));
|
||||||
create table &ds2 as
|
create table &ds2 as
|
||||||
select distinct key_hash,
|
select key_hash as &keyhash,
|
||||||
tgtvar_nm,
|
tgtvar_nm,
|
||||||
tgtvar_type,
|
tgtvar_type,
|
||||||
coalescec(oldval_char,newval_char) as charval,
|
coalescec(oldval_char,newval_char) as charval,
|
||||||
coalesce(oldval_num, newval_num) as numval,
|
coalesce(oldval_num, newval_num) as numval,
|
||||||
processed_dttm
|
processed_dttm as &processed
|
||||||
from &ds1
|
from &ds1
|
||||||
where is_pk=1
|
where is_pk=1
|
||||||
order by key_hash, processed_dttm;
|
order by &keyhash, &processed;
|
||||||
|
|
||||||
/* grab pk values */
|
/* grab pk values */
|
||||||
%local pk;
|
%local pk;
|
||||||
data _null_;
|
select distinct upcase(tgtvar_nm) into: pk separated by ' ' from &ds2;
|
||||||
set &ds2;
|
|
||||||
by key_hash processed_dttm;
|
|
||||||
call symputx('pk',catx(' ',symget('pk'),tgtvar_nm),'l');
|
|
||||||
if last.processed_dttm then stop;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%let ds3=%upcase(work.%mf_getuniquename(prefix=mpsd_keychar));
|
%let ds3=%upcase(work.%mf_getuniquename(prefix=mpsd_keychar));
|
||||||
proc transpose data=&ds2(where=(tgtvar_type='C'))
|
proc transpose data=&ds2(where=(tgtvar_type='C'))
|
||||||
out=&ds3(drop=_name_);
|
out=&ds3(drop=_name_);
|
||||||
by KEY_HASH PROCESSED_DTTM;
|
by &keyhash &processed;
|
||||||
id TGTVAR_NM;
|
id TGTVAR_NM;
|
||||||
var charval;
|
var charval;
|
||||||
run;
|
run;
|
||||||
@@ -13513,7 +13513,7 @@ run;
|
|||||||
%let ds4=%upcase(work.%mf_getuniquename(prefix=mpsd_keynum));
|
%let ds4=%upcase(work.%mf_getuniquename(prefix=mpsd_keynum));
|
||||||
proc transpose data=&ds2(where=(tgtvar_type='N'))
|
proc transpose data=&ds2(where=(tgtvar_type='N'))
|
||||||
out=&ds4(drop=_name_);
|
out=&ds4(drop=_name_);
|
||||||
by KEY_HASH PROCESSED_DTTM;
|
by &keyhash &processed;
|
||||||
id TGTVAR_NM;
|
id TGTVAR_NM;
|
||||||
var numval;
|
var numval;
|
||||||
run;
|
run;
|
||||||
@@ -13524,10 +13524,10 @@ run;
|
|||||||
/* now merge to get all key values and de-dup */
|
/* now merge to get all key values and de-dup */
|
||||||
%let ds5=%upcase(work.%mf_getuniquename(prefix=mpsd_merged));
|
%let ds5=%upcase(work.%mf_getuniquename(prefix=mpsd_merged));
|
||||||
data &ds5;
|
data &ds5;
|
||||||
length key_hash $32 processed_dttm 8;
|
length &keyhash $32 &processed 8;
|
||||||
merge &ds3 &ds4;
|
merge &ds3 &ds4;
|
||||||
by key_hash;
|
by &keyhash &processed;
|
||||||
if not missing(key_hash);
|
if not missing(&keyhash);
|
||||||
run;
|
run;
|
||||||
proc sort data=&ds5 nodupkey;
|
proc sort data=&ds5 nodupkey;
|
||||||
by &pk;
|
by &pk;
|
||||||
@@ -13535,10 +13535,18 @@ run;
|
|||||||
|
|
||||||
/* join to base table for preliminary stage DS */
|
/* join to base table for preliminary stage DS */
|
||||||
proc sql;
|
proc sql;
|
||||||
create table &outds as select "No " as _____DELETE__THIS__RECORD_____,
|
create table &outds as select "No " as _____DELETE__THIS__RECORD_____
|
||||||
b.*
|
%do x=1 %to %sysfunc(countw(&pk,%str( )));
|
||||||
|
,a.%scan(&pk,&x,%str( ))
|
||||||
|
%end;
|
||||||
|
%local notpkcols;
|
||||||
|
%let notpkcols=%upcase(%mf_getvarlist(&libds));
|
||||||
|
%let notpkcols=%mf_wordsinstr1butnotstr2(str1=¬pkcols,str2=&pk);
|
||||||
|
%do x=1 %to %sysfunc(countw(¬pkcols,%str( )));
|
||||||
|
,b.%scan(¬pkcols,&x,%str( ))
|
||||||
|
%end;
|
||||||
from &ds5 a
|
from &ds5 a
|
||||||
inner join &libds b
|
left join &libds b
|
||||||
on 1=1
|
on 1=1
|
||||||
%do x=1 %to %sysfunc(countw(&pk,%str( )));
|
%do x=1 %to %sysfunc(countw(&pk,%str( )));
|
||||||
and a.%scan(&pk,&x,%str( ))=b.%scan(&pk,&x,%str( ))
|
and a.%scan(&pk,&x,%str( ))=b.%scan(&pk,&x,%str( ))
|
||||||
@@ -13587,13 +13595,23 @@ data _null_;
|
|||||||
end;
|
end;
|
||||||
else if move_type='D' then do;
|
else if move_type='D' then do;
|
||||||
if first.key_hash then do;
|
if first.key_hash then do;
|
||||||
put "insert into &outds set _____DELETE__THIS__RECORD_____='No' " @@;
|
put "update &outds set _____DELETE__THIS__RECORD_____='No' " @@;
|
||||||
|
end;
|
||||||
|
if IS_PK=0 then do;
|
||||||
|
put " ," tgtvar_nm '=' @@;
|
||||||
|
cnt=count(oldval_char,'"');
|
||||||
|
charval=quote(trim(substr(oldval_char,1,32765-cnt)));
|
||||||
|
if tgtvar_type='C' then put charval @@;
|
||||||
|
else put oldval_num @@;
|
||||||
|
end;
|
||||||
|
else do;
|
||||||
|
if first.is_pk then put " where 1=1 " @@;
|
||||||
|
put " and " tgtvar_nm '=' @@;
|
||||||
|
cnt=count(oldval_char,'"');
|
||||||
|
charval=quote(trim(substr(oldval_char,1,32765-cnt)));
|
||||||
|
if tgtvar_type='C' then put charval @@;
|
||||||
|
else put oldval_num @@;
|
||||||
end;
|
end;
|
||||||
put " ," tgtvar_nm '=' @@;
|
|
||||||
cnt=count(oldval_char,'"');
|
|
||||||
charval=quote(trim(substr(oldval_char,1,32765-cnt)));
|
|
||||||
if tgtvar_type='C' then put charval @@;
|
|
||||||
else put oldval_num @@;
|
|
||||||
end;
|
end;
|
||||||
if last.key_hash then put ';';
|
if last.key_hash then put ';';
|
||||||
run;
|
run;
|
||||||
|
|||||||
@@ -30,7 +30,9 @@
|
|||||||
<h4> SAS Macros </h4>
|
<h4> SAS Macros </h4>
|
||||||
@li mf_getuniquefileref.sas
|
@li mf_getuniquefileref.sas
|
||||||
@li mf_getuniquename.sas
|
@li mf_getuniquename.sas
|
||||||
|
@li mf_getvarlist.sas
|
||||||
@li mf_islibds.sas
|
@li mf_islibds.sas
|
||||||
|
@li mf_wordsinstr1butnotstr2.sas
|
||||||
@li mp_abort.sas
|
@li mp_abort.sas
|
||||||
|
|
||||||
<h4> Related Macros </h4>
|
<h4> Related Macros </h4>
|
||||||
@@ -97,30 +99,28 @@ create table &ds1 (drop=libref dsn) as
|
|||||||
|
|
||||||
/* extract key values only */
|
/* extract key values only */
|
||||||
%let ds2=%upcase(work.%mf_getuniquename(prefix=mpsd_pks));
|
%let ds2=%upcase(work.%mf_getuniquename(prefix=mpsd_pks));
|
||||||
|
%local keyhash processed;
|
||||||
|
%let keyhash=%upcase(%mf_getuniquename(prefix=mpsdvar_keyhash));
|
||||||
|
%let processed=%upcase(%mf_getuniquename(prefix=mpsdvar_processed));
|
||||||
create table &ds2 as
|
create table &ds2 as
|
||||||
select distinct key_hash,
|
select key_hash as &keyhash,
|
||||||
tgtvar_nm,
|
tgtvar_nm,
|
||||||
tgtvar_type,
|
tgtvar_type,
|
||||||
coalescec(oldval_char,newval_char) as charval,
|
coalescec(oldval_char,newval_char) as charval,
|
||||||
coalesce(oldval_num, newval_num) as numval,
|
coalesce(oldval_num, newval_num) as numval,
|
||||||
processed_dttm
|
processed_dttm as &processed
|
||||||
from &ds1
|
from &ds1
|
||||||
where is_pk=1
|
where is_pk=1
|
||||||
order by key_hash, processed_dttm;
|
order by &keyhash, &processed;
|
||||||
|
|
||||||
/* grab pk values */
|
/* grab pk values */
|
||||||
%local pk;
|
%local pk;
|
||||||
data _null_;
|
select distinct upcase(tgtvar_nm) into: pk separated by ' ' from &ds2;
|
||||||
set &ds2;
|
|
||||||
by key_hash processed_dttm;
|
|
||||||
call symputx('pk',catx(' ',symget('pk'),tgtvar_nm),'l');
|
|
||||||
if last.processed_dttm then stop;
|
|
||||||
run;
|
|
||||||
|
|
||||||
%let ds3=%upcase(work.%mf_getuniquename(prefix=mpsd_keychar));
|
%let ds3=%upcase(work.%mf_getuniquename(prefix=mpsd_keychar));
|
||||||
proc transpose data=&ds2(where=(tgtvar_type='C'))
|
proc transpose data=&ds2(where=(tgtvar_type='C'))
|
||||||
out=&ds3(drop=_name_);
|
out=&ds3(drop=_name_);
|
||||||
by KEY_HASH PROCESSED_DTTM;
|
by &keyhash &processed;
|
||||||
id TGTVAR_NM;
|
id TGTVAR_NM;
|
||||||
var charval;
|
var charval;
|
||||||
run;
|
run;
|
||||||
@@ -128,7 +128,7 @@ run;
|
|||||||
%let ds4=%upcase(work.%mf_getuniquename(prefix=mpsd_keynum));
|
%let ds4=%upcase(work.%mf_getuniquename(prefix=mpsd_keynum));
|
||||||
proc transpose data=&ds2(where=(tgtvar_type='N'))
|
proc transpose data=&ds2(where=(tgtvar_type='N'))
|
||||||
out=&ds4(drop=_name_);
|
out=&ds4(drop=_name_);
|
||||||
by KEY_HASH PROCESSED_DTTM;
|
by &keyhash &processed;
|
||||||
id TGTVAR_NM;
|
id TGTVAR_NM;
|
||||||
var numval;
|
var numval;
|
||||||
run;
|
run;
|
||||||
@@ -139,10 +139,10 @@ run;
|
|||||||
/* now merge to get all key values and de-dup */
|
/* now merge to get all key values and de-dup */
|
||||||
%let ds5=%upcase(work.%mf_getuniquename(prefix=mpsd_merged));
|
%let ds5=%upcase(work.%mf_getuniquename(prefix=mpsd_merged));
|
||||||
data &ds5;
|
data &ds5;
|
||||||
length key_hash $32 processed_dttm 8;
|
length &keyhash $32 &processed 8;
|
||||||
merge &ds3 &ds4;
|
merge &ds3 &ds4;
|
||||||
by key_hash;
|
by &keyhash &processed;
|
||||||
if not missing(key_hash);
|
if not missing(&keyhash);
|
||||||
run;
|
run;
|
||||||
proc sort data=&ds5 nodupkey;
|
proc sort data=&ds5 nodupkey;
|
||||||
by &pk;
|
by &pk;
|
||||||
@@ -150,10 +150,18 @@ run;
|
|||||||
|
|
||||||
/* join to base table for preliminary stage DS */
|
/* join to base table for preliminary stage DS */
|
||||||
proc sql;
|
proc sql;
|
||||||
create table &outds as select "No " as _____DELETE__THIS__RECORD_____,
|
create table &outds as select "No " as _____DELETE__THIS__RECORD_____
|
||||||
b.*
|
%do x=1 %to %sysfunc(countw(&pk,%str( )));
|
||||||
|
,a.%scan(&pk,&x,%str( ))
|
||||||
|
%end;
|
||||||
|
%local notpkcols;
|
||||||
|
%let notpkcols=%upcase(%mf_getvarlist(&libds));
|
||||||
|
%let notpkcols=%mf_wordsinstr1butnotstr2(str1=¬pkcols,str2=&pk);
|
||||||
|
%do x=1 %to %sysfunc(countw(¬pkcols,%str( )));
|
||||||
|
,b.%scan(¬pkcols,&x,%str( ))
|
||||||
|
%end;
|
||||||
from &ds5 a
|
from &ds5 a
|
||||||
inner join &libds b
|
left join &libds b
|
||||||
on 1=1
|
on 1=1
|
||||||
%do x=1 %to %sysfunc(countw(&pk,%str( )));
|
%do x=1 %to %sysfunc(countw(&pk,%str( )));
|
||||||
and a.%scan(&pk,&x,%str( ))=b.%scan(&pk,&x,%str( ))
|
and a.%scan(&pk,&x,%str( ))=b.%scan(&pk,&x,%str( ))
|
||||||
@@ -202,13 +210,23 @@ data _null_;
|
|||||||
end;
|
end;
|
||||||
else if move_type='D' then do;
|
else if move_type='D' then do;
|
||||||
if first.key_hash then do;
|
if first.key_hash then do;
|
||||||
put "insert into &outds set _____DELETE__THIS__RECORD_____='No' " @@;
|
put "update &outds set _____DELETE__THIS__RECORD_____='No' " @@;
|
||||||
|
end;
|
||||||
|
if IS_PK=0 then do;
|
||||||
|
put " ," tgtvar_nm '=' @@;
|
||||||
|
cnt=count(oldval_char,'"');
|
||||||
|
charval=quote(trim(substr(oldval_char,1,32765-cnt)));
|
||||||
|
if tgtvar_type='C' then put charval @@;
|
||||||
|
else put oldval_num @@;
|
||||||
|
end;
|
||||||
|
else do;
|
||||||
|
if first.is_pk then put " where 1=1 " @@;
|
||||||
|
put " and " tgtvar_nm '=' @@;
|
||||||
|
cnt=count(oldval_char,'"');
|
||||||
|
charval=quote(trim(substr(oldval_char,1,32765-cnt)));
|
||||||
|
if tgtvar_type='C' then put charval @@;
|
||||||
|
else put oldval_num @@;
|
||||||
end;
|
end;
|
||||||
put " ," tgtvar_nm '=' @@;
|
|
||||||
cnt=count(oldval_char,'"');
|
|
||||||
charval=quote(trim(substr(oldval_char,1,32765-cnt)));
|
|
||||||
if tgtvar_type='C' then put charval @@;
|
|
||||||
else put oldval_num @@;
|
|
||||||
end;
|
end;
|
||||||
if last.key_hash then put ';';
|
if last.key_hash then put ';';
|
||||||
run;
|
run;
|
||||||
|
|||||||
Reference in New Issue
Block a user