Views
Learn more about views within Budibase
Views are virtual tables that present data from a table with a preset filter or grouping.
When you create a View within Budibase, it presents you with all the data from its linked table. This provides you with a canvas to manipulate your data without changing the data within the original table. This is crucial, as it protects your original data. It also allows you to create:
- Filters
- Sort
- Hide columns
When designing your UI, you can use a View with auto-generated screens, as well as for custom UI development. Say you have a table of Sales employees, and their total sales, you can create a view which gives you the total sales of all Sales employees. You can then reference the data from this View in the Design section of Budibase.
How to create a new view
To create a new view, click the Create view
button, and give it a name.
Filters
One of the core features of views is the ability to filter rows according to particular criteria. When a Row is filtered, it is not deleted—it's just hidden from the particular view you're using and remains within the table (views are virtual tables!).
Try adding filters when:
- You need to focus on rows that meet certain conditions (e.g. Classes between May and June, and taught by Albert Einstein).
- You need to display certain information, to certain people (e.g Each salesperson can only view their own commission).
How to create a new filter
To create a new filter:
- Click the
Filter
button - Click
Add Filter
- Select the Column you would like to filter
- Select a filter function
- Type your query
- Click
Save
You can also save a filtered table as a new view:
View Calculations
View calculations allow you to run certain mathematical operations on your data, akin to those available in traditional SQL-based databases.
- Average - find the arithmetic mean-average column's values, (optionally) grouped by a column.
- Sum - find the sum-total of a column's values, (optionally) grouped by a column.
- Minimum - find the minimum value of a column's values, (optionally) grouped by a column.
- Maximum - find the maximum value of a column's values, (optionally) grouped by a column.
- Count - count how many occurrences of each value a column contains, (optionally) grouped by a column.
Average, Sum, Minimum, and Maximum
Average, Sum, Minimum, and Maximum must all be performed on number columns. When used independently they will return a single row, and when used in conjunction with a "Group By" they will return a row for each unique value in the group by column.
For example - "Sum Total Revenue" configured as "Calculate the Sum
of Total Revenue
Group By None
" will return a single row, totalling all revenue.
Grouping by Sales Channel will return a row for each unique value in the Sales Channel column (Offline and Online)
Grouping by Region, Country, Sales Channel and Order Priority will, again, return a new row for each unique combination of those attributes, and calculate the sum of Total Revenue for each combination. Naturally, the more specific the calculations become, the more granular the data, the more rows are returned.
Count
The Count calculation can be used to find how many rows meet the specified criteria. Using "Calculate the Count
of Order ID
Group by Country
" we can see how many unique order IDs there are per country.
We can then Group by additional criteria to refine the data further. For example grouping by country and sales channel will show us how many online and offline sales were made per country.
Views and View Calculations as Data Sources
Views and View Counts can be used as Data Sources, and manipulated in the same ways. Using a view calculation like "Calculate the Sum of Total Revenue, Group by Country" allows us the find the total revenue of sale per country. We could then use this in a repeater block, as a sales leaderboard.
Add a Repeater Block, and set the Data Source to the view total_revenue_by_country
, then set the Sort Column to be Sum Total Revenue, descending, limited to 10. This will show us the top 10 countries by sum total sales revenue.
Inside the repeater block, add a container and nest inside it 3 Headline components
Set the first headline component to {{ add New Repeater Block.Row Index 1 }}
- This is taking the Row Index and adding 1 to it. (Index starts counting from Zero, so in order to use row-index as the rankings we must add 1)
Set the second headline component to {{ New Repeater Block.total_reveue_by_country.Sum Total Revenue }}
- this fetches the sum total of the revenue. You can then set the third headline component to{{ New Repeater Block.total_reveue_by_country.Country }}
, and just like that we've built a basic leaderboard for Total Revenue by Country.
Updated about 2 months ago