楼主: 9days
15283 6

关于 SQL 中用 case when in (a list) [推广有奖]

  • 0关注
  • 0粉丝

小学生

64%

还不是VIP/贵宾

-

威望
0
论坛币
10 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
51 点
帖子
9
精华
0
在线时间
4 小时
注册时间
2013-8-29
最后登录
2013-10-4

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币

要转换这段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;


二维码

扫码加我 拉你入群

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

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

关键词:when Case list CAS whe create ERROR

沙发
bobguy 发表于 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;

使用道具

藤椅
9days 发表于 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;

使用道具

板凳
9days 发表于 2013-10-3 23:15:12 |只看作者 |坛友微信交流群
还有就是,是不是可以总结说 case when不能跟in (list).

使用道具

报纸
bobguy 发表于 2013-10-4 10:42:53 |只看作者 |坛友微信交流群
9days 发表于 2013-10-3 23:14
谢谢啊,太高深了。

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

substr can be replaced with char function for efficiency.

使用道具

地板
bobguy 发表于 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'  

使用道具

7
9days 发表于 2013-10-5 01:19:13 |只看作者 |坛友微信交流群
谢谢,按照你的code试出来了。

使用道具

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-5-3 17:36