Do not input private or sensitive data. View Qlik Privacy & Cookie Policy.
Skip to main content

Announcements
Qlik Connect 2026! Turn data into bold moves, April 13 -15: Learn More!
cancel
Showing results for 
Search instead for 
Did you mean: 
j0nimost1
Contributor II
Contributor II

Convert Measure to Dimension

I have this if statement that I wish to use as a dimension.

 

=if(Count(distinct AssessmentId) <= 4, 'Low Risk',
if(Count(distinct AssessmentId) > 4 and Count(distinct AssessmentId) <= 10, 'Medium Risk',
'High Risk'))

 

Currently, it can only be used as a measure kindly assist me in converting it to a Dimension

Labels (3)
7 Replies
haskia
Partner - Contributor III
Partner - Contributor III

You need to provide at least one other dimension via aggr()-formula to show where the distinct Id's should be counted.
In the example below I added a fictional  "CustomerID" field for demonstration. Simply replace this field with one or more dimensions. 

=
if(AGGR(COUNT(DISTINCT AssessmentId),CustomerID) <= 4, 'Low Risk',
if(AGGR(COUNT(DISTINCT AssessmentId),CustomerID) > 4 and AGGR(COUNT(DISTINCT AssessmentId),CustomerID) <= 10, 'Medium Risk',
'High Risk'))

 

j0nimost1
Contributor II
Contributor II
Author

This just returns High risk

iswarya
Partner - Creator
Partner - Creator

Hi,

Can you share a sample data

stevedark
Partner Ambassador/MVP
Partner Ambassador/MVP

Whilst you can use calculations as dimensions it is not generally a good idea, and the selections can be a bit weird.

The best bet is to pre-aggregate the data on the load, so that you have a field which can then be used as a dimension.

What you don't mention above is what the dimension is that you are aggregating over. I shall assume it's PolicyID for this example.

Insert this code after the load of your main table, to do the aggregation:

RiskStatus:
LOAD
  PolicyID,
  if(Count(distinct AssessmentId) <= 4, 'Low Risk',
    if(Count(Count(distinct AssessmentId) <= 10, 'Medium Risk',
    'High Risk')) as [Risk Rating],
  count(distinct AssessmentId) as Assessments
RESIDENT ExistingTable
GROUP BY PolicyID;

 

This can add a bit of overhead to your load script, depending on number of rows, but it will make your life much easier and make use of your application much more efficient.

The thing to bear in mind (and this may dictate whether this approach works for you) is that the Risk Rating will not change based on selections. With the code in the front end, selecting an AssessmentId will make the result automatically Low Risk, by calculating it in the load script selections will not have an impact.

Hope that helps.

Ksrinivasan
Specialist
Specialist

Hi,

just you can add under the field of "distinct AssessmentId" in Main table,

if(Count(distinct AssessmentId) <= 4, 'Low Risk',
if(Count(distinct AssessmentId) > 4 and Count(distinct AssessmentId) <= 10, 'Medium Risk',
'High Risk')) as Risk_Status,

then you can call Risk_Status field as Dimension in chart or table.

 

=if(Count(distinct AssessmentId) <= 4, 'Low Risk',
if(Count(distinct AssessmentId) > 4 and Count(distinct AssessmentId) <= 10, 'Medium Risk',
'High Risk'))

bing_jville
Contributor III
Contributor III

copy your script and paste into the loading script

a new aggregated table is needed as well