data:image/s3,"s3://crabby-images/72807/7280789bb888da3eaa54e3cb689ec358ca2bdb47" alt="Contributor"
Contributor
2021-08-12
06:09 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Help with using crosstables in resident load
Hi,
I have 3 fields: Item, Type and Value. Each item has 2 types, A and B. I would like to have 3 fields: Item, A and B so A would be Value when type is A and B would be Value when type is B. In other words I would like to get rid of Type field so I could sum Type A and B values separately easily. How would I do this, with crosstable?
Thanks in advance.
547 Views
1 Solution
Accepted Solutions
data:image/s3,"s3://crabby-images/14c04/14c045bb2dbd64960333fed92f87ae54da4b9ec2" alt="chrismarlow chrismarlow"
data:image/s3,"s3://crabby-images/58c5b/58c5b0d39ca0ccf33eceef9350b4faf96961e5b0" alt="Specialist II"
Specialist II
2021-08-12
06:18 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
I think crosstable would be going the other way, so taking 2 fields A & B & turning them into a type fields, this sounds more like a pivot, so something like;
Load
Dim,
Sum(If(Type='A',Value)) AS A,
Sum(If(Type='B',Value)) AS B
Group by Dim;
LOAD * INLINE[
Dim, Type, Value
X, A, 10
X, B, 5
Y, A, 20
Y, B, 15
];
Cheers,
Chris.
531 Views
2 Replies
data:image/s3,"s3://crabby-images/14c04/14c045bb2dbd64960333fed92f87ae54da4b9ec2" alt="chrismarlow chrismarlow"
data:image/s3,"s3://crabby-images/58c5b/58c5b0d39ca0ccf33eceef9350b4faf96961e5b0" alt="Specialist II"
Specialist II
2021-08-12
06:18 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
Hi,
I think crosstable would be going the other way, so taking 2 fields A & B & turning them into a type fields, this sounds more like a pivot, so something like;
Load
Dim,
Sum(If(Type='A',Value)) AS A,
Sum(If(Type='B',Value)) AS B
Group by Dim;
LOAD * INLINE[
Dim, Type, Value
X, A, 10
X, B, 5
Y, A, 20
Y, B, 15
];
Cheers,
Chris.
532 Views
data:image/s3,"s3://crabby-images/368bc/368bcf7eceba9f687523d207ee8d6d000e70ad9d" alt="MVP"
MVP
2021-08-12
06:25 AM
- Mark as New
- Bookmark
- Subscribe
- Mute
- Subscribe to RSS Feed
- Permalink
- Report Inappropriate Content
@pgkrsk by using Generic Load, like :
Input:
LOAD * INLINE [
Item, Type, Value
1, A, 10
2, B, 11
3, A, 12
4, B, 13
];
DATA:
Generic LOAD
Item,
Type,
Value
Resident Input;
CombinedGenericTable:
Load distinct Item Resident Input;
Drop Table Input;
FOR i = NoOfTables()-1 to 0 STEP -1
LET vTable=TableName($(i));
//trace $(i) - '$(vTable)';
IF WildMatch('$(vTable)', 'DATA.*') THEN
LEFT JOIN ([CombinedGenericTable]) LOAD distinct * RESIDENT [$(vTable)];
DROP TABLE [$(vTable)];
ENDIF
NEXT i
output:
Regards,
Taoufiq ZARRA
"Please LIKE posts and "Accept as Solution" if the provided solution is helpful "
(you can mark up to 3 "solutions") 😉
Taoufiq ZARRA
"Please LIKE posts and "Accept as Solution" if the provided solution is helpful "
(you can mark up to 3 "solutions") 😉
518 Views
data:image/s3,"s3://crabby-images/6f3fe/6f3fea5430d1754130de1887eb50c1c08457f027" alt=""