首页 > 其他 > 详细

HASH 何时将key加载到h.definedata()中

时间:2017-09-01 14:21:21      阅读:264      评论:0      收藏:0      [点我收藏+]

在实践从地址中提取省份时,发现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()中

原文:http://www.cnblogs.com/Anni-love-Ferris-wheel/p/7462806.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!