2015-01-06 57 views
2

我试图在Report Studio中生成数据交叉表,但失败了。Cognos Crosstab

在列表我的数据是:

  • ID,产品,
  • 1,产品1,d
  • 1,产品2,C
  • 1,产品3,d
  • 2,Product1,C
  • 2,Product2,C
  • 2,Product3,A

我想的一个交叉表:

  • ID,产品1,产品2,产品3
  • 1,d,C,d
  • 2,C,C,A

但是我在Cognos中生成的交叉表给我提供了全部空白或“等级”的计数或总和。

  • ID,产品1,产品2,产品3
  • 1,
  • 2,

任何帮助将不胜感激。提前谢谢你。

最佳, 汤姆

+0

你能展示任何你已经试过的东西吗? – Flexicoder

回答

0

如果我理解正确的话,你需要使用一个case语句为您的产品档次列:

ID  PRODUCT1   
1  case when Product = 'Product1' then grade else null end 

您可能需要包装case语句中MAX,不确定没有尝试。

3

交叉表仅适用于数字。 所以测量针对交叉表不应该是A,B,C.

  1. 使用号码作为测量(A = 1,B = 2等),使用MAX或MIN作为聚集体。
  2. 然后将您的号码转换为单元格内的文本。例如,将Source Type属性更改为Report Expression并编写合适的公式。 (或解锁电池和内部阻力查询计算)

你不能做的事情一样

ID |产品1 |产品2 |产品3

1 | D,A | C | D

2 | C | C | A

简单。

0

从你说的你需要它看起来像一个列表是最好的选择。

ID | Case when [Product] = 'Product1' then [grade] end | same for product 2 and 3