码迷,mamicode.com
首页 > 其他好文 > 详细

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

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

标签:get   遍历   data   bsp   fine   pre   def   数据集   key值   

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

标签:get   遍历   data   bsp   fine   pre   def   数据集   key值   

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

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!