Skip to main content
Announcements
Join us at Qlik Connect for 3 magical days of learning, networking,and inspiration! REGISTER TODAY and save!
cancel
Showing results for 
Search instead for 
Did you mean: 
Chanty4u
MVP
MVP

RE:Change if

Hi all ,

swuehl,M G,Peter Cammaert,jagan mohan rao appala,Marco Wedel

How to change the below if statements to case statements?

Anyone help me on this.

If(MATCH_TYPE='VOD', 'Tier 1',

          If(NOT MATCH_TYPE(NETWORK_TYPE,'Broadcast','Cable') AND NOT IsNull(PROGRAM_NAME),

               If(Num#(Left(TIMESHIFT_INDICATOR_ID,2)) >= 10 AND Num(Left(TIMESHIFT_INDICATOR_ID,2)) <= 16

AND Count(Distinct USERS_META_ID) <> 0,'Tier 2','Tier 1')

          )

   ) as Field_name

if(MATCH_TYPE = 'VOD','Tier 1',

if(MATCH_TYPE <> 'VOD' AND NETWORK_TYPE IN ('Broadcast', 'Cable') AND PROGRAM_NAME <> null,

if(TIMESHIFT_INDICATOR_ID = 10 AND SAMPLE <> 0,

if(TIMESHIFT_INDICATOR_ID = 11 AND SAMPLE <> 0,

if(TIMESHIFT_INDICATOR_ID = 12 AND SAMPLE <> 0,

if(TIMESHIFT_INDICATOR_ID = 13 AND SAMPLE <> 0,

if(TIMESHIFT_INDICATOR_ID = 14 AND SAMPLE <> 0,

if(TIMESHIFT_INDICATOR_ID = 15 AND SAMPLE <> 0,

if(TIMESHIFT_INDICATOR_ID = 16 AND SAMPLE <> 0,'Tier 2','Tier 1')))))))))

as field_name

Message was edited by: suri qv

22 Replies
jyothish8807
Master II
Master II

Hi Suresh,

Qlikview have "switch case" function. You can find it in Help.

It might be helpful.


Regards

KC

Best Regards,
KC
Chanty4u
MVP
MVP
Author

thnx KC will look into that  till i get any updates frm experts.

Chanty4u
MVP
MVP
Author

thnx fr reply raj... wil chk nd update u if it wrks r nt.

Peter_Cammaert
Partner - Champion III
Partner - Champion III

In QlikView script, SWITCH... CASE is a control statement that is to be used outside of other statements like LOAD etc...

LOAD statements only accept functions, like IF() (this is a function, not a statement, although there is an IF control statement as well).

In a LOAD statement, you can use a Pick/Match combo to simplify IFs that test for individual values. In your last example, the last part is pretty useless because IMHO it tests for TIMESHIFT_INDICATOR_ID being equal to 10 AND 11 AND 12 AND 13..., all at the same time, which is obviously never the case. However, if you want to check whether a field is within a range of consecutive numerical values, do like:

:

IF ((TIMESHIFT_INDICATOR_ID >= 10) AND (TIMESHIFT_INDICATOR_ID <= 16) AND (SAMPLE <> 0),

  'Tier 2','Tier 1')

Best,

Peter

jagan
Luminary Alumni
Luminary Alumni

Hi,

Case statement cannot be applied in Load statement, it should be applied outside Load statement like FOR, WHILE etc.

Regards,

Jagan.

jagan
Luminary Alumni
Luminary Alumni

Example from Qlikview help file.

Examples:

switch I

case 1

load '$(I): CASE 1' as case autogenerate 1;

case 2

load '$(I): CASE 2' as case autogenerate 1;

default

load '$(I): DEFAULT' as case autogenerate 1;

end switch

Chanty4u
MVP
MVP
Author

thnx jagan,and

will try both of ur logic.. 

jagan
Luminary Alumni
Luminary Alumni

Hi,

You can fine tune this by

If(MATCH_TYPE = 'VOD','Tier 1',

If(MATCH_TYPE <> 'VOD' AND Match(NETWORK_TYPE, 'Broadcast', 'Cable') AND PROGRAM_NAME <>null,

AND SAMPLE <> 0 AND MATCH(TIMESHIFT_INDICATOR_ID, 10, 12, 13, 14, 15, 16), 'Tier 2', 'Tier 1'))

as field_name


Hope this helps you.

Regards,

jagan.

Chanty4u
MVP
MVP
Author

And one more info is...

if am  usng with in Select statment  not in load statmnt.

am usng inside Select statmnt how shud i write this  query?

If(MATCH_TYPE='VOD', 'Tier 1',

          If(NOT MATCH_TYPE(NETWORK_TYPE,'Broadcast','Cable') AND NOT IsNull(PROGRAM_NAME),

               If(Num#(Left(TIMESHIFT_INDICATOR_ID,2)) >= 10 AND Num(Left(TIMESHIFT_INDICATOR_ID,2)) <= 16

AND Count(Distinct USERS_META_ID) <> 0,'Tier 2','Tier 1')

          )

   ) as Field_name

Chanty4u
MVP
MVP
Author

hi jagan.

This is not inside the load stmnt . it is related select stmnt. wit in that how can i write?