Mastering Tableau: Implementing Parameters for Multiple Inputs
Enhance Your Tableau Skills: Creating Parameters for Multiple Inputs
Exploring Tableau’s Advanced Features: Multi-Input Parameters Demystified
Introduction
We were working on a project in which the requirement was to pass multiple values as input to the parameter. In the same Project for a few dashboards, we faced challenges while developing the dashboard because of huge data. It was taking too long to execute any command and therefore it was very difficult to build the dashboard either using live connection or using an extract.
To overcome the above problem and meet the requirement, we came up with the below solutions:
- By using CONTAINS() Function
- By using INSTR() Function
By using CONTAINS() Function
CONTAINS is a Tableau function with the help of which we were able to pass multiple values as input to the parameter.
Understanding Parameters in Tableau
Step-by-Step Guide: Creating a Parameter for Multiple Inputs
Practical Examples: Leveraging Multi-Input Parameters in Tableau
Tips and Tricks: Optimizing Your Analysis with Multi-Input Parameters
Getting Started: Introduction to Tableau Parameters
Creating a Multi-Input Parameter: A Detailed Walkthrough
Applying Multi-Input Parameters: Real-World Use Cases
Advanced Techniques: Maximizing the Potential of Multi-Input Parameters
Please follow the below steps to create a parameter in Tableau which will take multiple values as input.
Step 1:
Create a string parameter and default it to blank
data:image/s3,"s3://crabby-images/cb354/cb3546d47c4d9fcb5cf68ff66426203b7a351213" alt=""
Step 2:
Create a calculated field as below
Department ID Calc = CONTAINS ([DEPARTMENT ID], (Department ID))
Here “[DEPARTMENT ID]” is a Tableau Parameter and “Department ID” is the corresponding column from the database to which we want to apply this parameter
data:image/s3,"s3://crabby-images/24842/248420c4afd173d3b13a124dae5f66abe8d45cc7" alt=""
Step 3:
Bring Department ID Calc to filter shelf and filter it to True
data:image/s3,"s3://crabby-images/35ba6/35ba638a53983cef950b6826c6e80d1f6b409c9d" alt=""
Step 4:
Pass multiple values with any delimiter through DEPARTMENT ID parameter
data:image/s3,"s3://crabby-images/26f07/26f07d139b9c537992d0c34b53459ea76154efd7" alt=""
Limitations and workaround for it
- CONTAINS() Function works only with those fields which are having string data type.
- INSTR() function will overcome this limitation.
By using INSTR() Function
For those dashboards in which we were facing challenges because of huge volume of data, we restricted the data by using parameters in custom SQL query. But when we used parameters in custom SQL query, we were not able to use CONTAINS() function to pass multiple values as input to the parameter. In this case, we used the INSTR() function to meet our requirements.
NOTE: INSTR() function will work only with the ORACLE database.
Please follow the below steps to make a parameter in tableau which will take multiple values as input.
Step 1:
Fetch the data from the ORACLE database using custom SQL query.
data:image/s3,"s3://crabby-images/52ff9/52ff98c106d3a039e5db15d01c99e0043ede2cd9" alt=""
Step: 2
Create a string parameter and default it to blank
data:image/s3,"s3://crabby-images/a732d/a732d4a4ac737998a30196c1275d031638479ade" alt=""
Step 3:
Use the INSTR() function and modify the custom SQL query.
data:image/s3,"s3://crabby-images/54f9b/54f9b7cc15204c5b72a298f5ef989e799f772807" alt=""
Here “<Parameters.DEPARTMENT ID>” is a Tableau Parameter and “DEPARTMENT_ID” is the corresponding column from the database on which we want to apply this parameter.
Step 4:
Pass multiple values with any delimiter through the DEPARTMENT ID parameter.
data:image/s3,"s3://crabby-images/bdbf3/bdbf3696b6c36aa5f9e1cf68efe5aeadb797ae62" alt=""
NOTE: If user wants to search data based on only few characters and get the corresponding result, we can follow below approach.
Step: 1
Create a string parameter and default it to blank
data:image/s3,"s3://crabby-images/439c5/439c56ac31fa1ff2de90f11b0587a4d10d17c0c8" alt=""
Step 2:
Use SUBSTR() with INSTR() function and modify the custom SQL query.
data:image/s3,"s3://crabby-images/ab284/ab284a12a253df3d9b9bf35cda2cf87605773080" alt=""
Here “<Parameters.Email>” is a Tableau Parameter and “EMAIL” is the corresponding column from the database on which we want to apply this parameter.
Step 3:
Pass multiple values with any delimiter through the Email parameter.
data:image/s3,"s3://crabby-images/349ed/349ed9c57f7de632033565bcf86769d295b20833" alt=""