全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
15685 6
2013-10-01

要转换这段data step 为sql。
if substr(postal_code,1,1) in ('K','L','M','N','P') THEN PROVINCE='ON' ;
ELSE PROVINCE='XX';

想用下面when in (list of value)的方式但是报错:ERROR: Operand of WHEN clause 1 is not the same data type as the CASE operand.
case  substr(postal_code,1,1)       
          when in ('K','L','M','N','P')  THEN 'ON'
          ELSE 'XX'
          END AS PROVINCE


目前成功的方式如下:
proc sql;
   create table province as
   select *,
      case  substr(postal_code,1,1)       
          when 'K' then 'ON'
          when 'L' then 'ON'
          when 'M' then 'ON'
          when 'N' then 'ON'
          when 'P' then 'ON'
          ELSE 'XX'
          END AS PROVINCE
   FROM RATE ;
QUIT;


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2013-10-2 06:44:02
Here is correct syntax,

data t1;
   do c='KP','LV','P','U','V';
     output;
        end;
run;

proc sql;
   select case
          when c = 'K' or C='L' then 'KL'   
          else 'NA'
          end as Ctrans
      from t1;
quit;

proc sql;
   select c, case
          when substr(c,1,1) in( 'K' ,'L') then 'KL'
          when c in( 'U' ,'V') then 'UV'  
          else 'NA'
          end as Ctrans
      from t1;
quit;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-10-3 23:14:27
谢谢啊,太高深了。

另外我没说明白我的目的,我是想让code简洁些。我做了下面这个,还能再简单点吗?还是觉得很罗嗦。
proc sql;
   create table province2 as
   select *,  case  indexc(substr(postal_code,1,1), 'KLMNP')
          when 0 then 'XX'
          ELSE 'ON'
          END AS PROVINCE
   FROM RATE ;
QUIT;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-10-3 23:15:12
还有就是,是不是可以总结说 case when不能跟in (list).
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-10-4 10:42:53
9days 发表于 2013-10-3 23:14
谢谢啊,太高深了。

另外我没说明白我的目的,我是想让code简洁些。我做了下面这个,还能再简单点吗?还 ...
NO.

substr can be replaced with char function for efficiency.
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2013-10-4 10:43:57
9days 发表于 2013-10-3 23:15
还有就是,是不是可以总结说 case when不能跟in (list).
No. It is not true. My example has

when c in( 'U' ,'V') then 'UV'  
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群