HASH 何时将key加载到h.definedata()中
Posted Anni爱摩天轮
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了HASH 何时将key加载到h.definedata()中相关的知识,希望对你有一定的参考价值。
在实践从地址中提取省份时,发现HASH没作用?
DATA D.T1(KEEP= PROVINCE REPORT_ID GET_DATE ADDRESS);
SET D.T;
IF _N_=0 THEN SET S.PROVINCE_1;/*该数据集包含所有省份简称P_1 和省份全称PROVINCE*/
IF _N_=1 THEN DO;
DECLARE HASH H_P(DATASET : ‘S.PROVINCE_1‘,ORDERED:‘NO‘);
DECLARE Hiter HI_P(‘H_P‘);
H_P.DEFINEKEY(‘Province_ShortName‘);
H_P.DEFINEDATA(‘P_1‘);
H_P.DEFINEDONE();
CALL MISSING (P_1);
END;
IF Province =‘‘ THEN DO;
RC=HI_P.FIRST();
DO WHILE(RC=0);
IF FIND(ADDRESS,COMPRESS(Province_ShortName))>0 THEN
DO;
TEMP= COMPRESS(P_1);
Province=TEMP;
END;
RC=HI_P.NEXT();
END;
END;
RUN;
此处HASH没起到作用是因为遍历语句中用到key值的判断,但是定义HASH时,并没有将Province_ShortName(key)放到需要保存的数据里
H_P.DEFINEDATA(‘P_1‘);改为H_P.DEFINEDATA(‘P_1‘,‘Province_ShortName’);
以上是关于HASH 何时将key加载到h.definedata()中的主要内容,如果未能解决你的问题,请参考以下文章