首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >将行对转换为单行

将行对转换为单行
EN

Stack Overflow用户
提问于 2015-07-07 03:56:15
回答 2查看 79关注 0票数 1

我有张像这样的桌子

代码语言:javascript
运行
复制
|=========|=====|==================|==============|===========|===========|
| PREFIX  | ID  | PREVIOUS_PREFIX  | PREVIOUS_ID  | VENDOR_1  | VENDOR_2  |
|=========|=====|==================|==============|===========|===========|
| A       | 1   |                  |              | JAC       |      BOA  |
|---------|-----|------------------|--------------|-----------|-----------|
| B       | 2   | C                | 99           | LCH       |      GS   |
|---------|-----|------------------|--------------|-----------|-----------|
| B       | 3   | C                | 99           | LCH       |      JPM  |
|---------|-----|------------------|--------------|-----------|-----------|

我需要把它变成这样的桌子

代码语言:javascript
运行
复制
|=========|=====|==================|==============|===========|===========|
| PREFIX  | ID  | PREVIOUS_PREFIX  | PREVIOUS_ID  | VENDOR_1  | VENDOR_2  |
|=========|=====|==================|==============|===========|===========|
| A       | 1   |                  |              | JAC       |      BOA  |
|---------|-----|------------------|--------------|-----------|-----------|
| C       | 99  |                  |              | GS        |      JPM  |
|---------|-----|------------------|--------------|-----------|-----------|

这就是:

  1. 对于没有PREVIOUS_PREFIXPREVIOUS_ID的行,它将该行保留为
  2. 用于使用PREVIOUS_PREFIXPREVIOUS_ID的行:
    1. 它创建了一个新行,其PREFIXPREVIOUS_PREFIX相同,IDPREVIOUS_ID相同,VENDOR_1VENDOR_2是原始行不常见的供应商。
    2. 它删除原始行对。

EN

Stack Overflow用户

发布于 2015-07-07 06:44:25

一个稍微简单的解决方案是将单个观察扩展为2个观察,并将供应商合并到单变量中,并将previous_prefix和前缀合并到一起,以获得new_prefix和类似的id。按此顺序获取数据可以解决单个sql中的问题。看看这个草案代码。

代码语言:javascript
运行
复制
DATA WANT;
SET HAVE;
  PREFIX_NEW =COALESCEC(PREVIOUS_PREFIX,PREFIX);
  ID_NEW     =COALESCEC(PREVIOUS_ID    ,ID);
IF NOT MISSING(VENDOR_1) THEN VENDOR=VENDOR_1; 
OUTPUT;
IF NOT MISSING(VENDOR_2) THEN VENDOR=VENDOR_2; 
OUTPUT;
RUN;

PROC SQL;
SELECT PREFIX_NEW
     , ID_NEW
     , MIN(VENDOR) AS VENDOR_1
     , MAX(VENDOR) AS VENDOR_2
FROM ( SELECT PREFIX_NEW
            , ID_NEW
            , VENDOR
            , COUNT(*) AS COUNTER
         FROM WANT
         GROUP BY 1,2,3
         HAVING COUNTER=1
      )
;
QUIT;

希望这会有帮助!

票数 0
EN
查看全部 2 条回答
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31259475

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档