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’);

 

posted @ 2017-09-01 13:27  Anni爱摩天轮  阅读(184)  评论(0编辑  收藏  举报