Fast Data Search, Slice and Dice
Oftentimes, you want to segment and drill down into parts of your data stores. Followed by searching and filtering your data by a certain property, you needed to perform actions on it, such as sending selected data to an API or downloading it as a CSV.
In this tutorial, we will build an admin panel that allows you to quickly filter a database by a column and download selected rows, all from the UI. Our end application will look like the following:
data:image/s3,"s3://crabby-images/7b0f5/7b0f5165babb4855027f2203def20c40b1d26ea6" alt="Messages Image(688916538).png 3258"
Enable search on scattered data sources
Combine this tutorial with the Sql on Any Datasource tutorial to quickly build a search, slice and dice dashboard on scattered data sources.
Start by creating a new application in Datasiv. Then, drag a table into the builder.
data:image/s3,"s3://crabby-images/6147e/6147e02b34d01a89ac63a7662340fd28f6d3f401" alt="Messages Image(4099867845).png 3258"
Make sure to set the Select Row property to multi
.
Next, click Add Data Query and choose Sql Api
. Datasiv allows you to call and display data queries to a variety of sources from your application.
DataSiv provides integrations and read/write capabilities across multiple sources
Although we use a SQL in this tutorial, you can swap these out with other supported integrations, such as a Rest Api Endpoint, GraphQL, Salesforce, Stripe, etc.
data:image/s3,"s3://crabby-images/ebb9d/ebb9d9c29bd40e41b1cac7b0542dfe847727e47b" alt="3.png 2586"
We will be using our dummy database for this task.
Set the Resource to Chinook DB (builitin) (readonly)
, and for the SQL Query to Select * from Customers
.
data:image/s3,"s3://crabby-images/6a9e8/6a9e8e3e6d2b72c8f8cd5b6df04e43a73f8fbb3c" alt="Resource Customers.png 2480"
Save the query as sql0
.
Each customer comes from a state. We want to be able to filter and view customers only in a specific state. To do so, let's create create another database query with the same database, and set the SQL Query to Select Distinct State from Customers
.
data:image/s3,"s3://crabby-images/20c54/20c544d2704c5cffe02971888dc093b865c96784" alt="Resource Distinct State.png 2496"
Save the query as sql1
.
data:image/s3,"s3://crabby-images/09683/09683065c3d4d0b78418faa3c4590ca5c6811ca1" alt="Messages Image(131993237).png 2680"
Next, go back to the main editor, and click Add transform. We will process the data from sql1
so we can input it into a Select
component. Select Transform
for your transform.
Transforms allow you to preprocess and postprocess your data
Transforms, such as the one we're about to create, allow you an easy way to mix and merge data sources together, filter them, or write code to get it into the right format before putting it into another frontend component. You can write raw javascript, client-side SQL, or other transforms to get started quickly.
data:image/s3,"s3://crabby-images/4c0b1/4c0b1a557c208aefb66cdc461f2d9386dafa3474" alt="6.png 2590"
For the data source, choose queries.sql1.data
. This will run the transform on the data property of the sql1 query.
data:image/s3,"s3://crabby-images/64081/640810feebac8c2e0ad887b09728dff9ba9cc2c3" alt="7.png 1972"
For the transform, write (element, index) => {return {key: element.State, value: element.State}}
. Save the transform as transform0
.
data:image/s3,"s3://crabby-images/76051/7605161a066764a42fb6bea3d9c01574133e6df5" alt="9.png 2016"
Add a Select component to the frontend.
data:image/s3,"s3://crabby-images/52b47/52b47dd9b99b8d99d20a6aee41e576e8e28a06f3" alt="Messages Image(4011924125).png 3252"
In the right hand menu, click Edit Data
, and select data.transform0.result
.
data:image/s3,"s3://crabby-images/440d4/440d453fb5296018d12eded5b24aa844e00dbb30" alt="10.png 1982"
Congratulations! Now the select in the frontend allows you to choose from States
in the database.
data:image/s3,"s3://crabby-images/19585/19585fc9f50061b4eecc3408ec66fabbf2211ce4" alt="Messages Image(3574248237).png 3258"
How to reference DataSiv components (such as selected items from a select view)
All component properties are stored in a global key value store that other components in the app are able to access. You are able to reference other components using javascript dictionary terminology.
In this instance, we would like to reference the
key
value under the selectedItem* property from the select0 Select component. All data components are stored under the global data** key, hence, we type indata.select0.selectedItem.key
.
Finally, we want to only display customer data in the table that comes from the selected state. Modify the SQL Query for data query query0
to be Select * from Customers WHERE State = {{data.select0.selectedItem.key}}
data:image/s3,"s3://crabby-images/8f39d/8f39dd5c26fd2e399a454c1301c29252bb965c44" alt="13.png 1618"
Now the customer data in the table only includes customers from the selected state.
data:image/s3,"s3://crabby-images/858a1/858a119ffe3ab9af2cb87e840126347e2ffaa1a2" alt="Messages Image(1760630580).png 3256"
Finally, we'll add a download button so that you can download selected rows.
Select several rows from the table.
data:image/s3,"s3://crabby-images/335b8/335b811a3059aa0df6f7bb3131ae4134e89fd4c7" alt="Messages Image(2056678171).png 3252"
Add a Download Button to the frontend.
data:image/s3,"s3://crabby-images/83df0/83df0d4c9cf19b0aaa99b022db46762ff15191c3" alt="Messages Image(3409364174).png 3254"
In the righthand sidebar menu, click Edit Data, and choose data.table0.selectedRow
as your data source.
Congratulations! You can now filter customer data by a database column (state), select and download rows, all without writing SQL queries.
data:image/s3,"s3://crabby-images/e8079/e8079db34dd11fbbb72ef78beb7428f2009545be" alt="Messages Image(307199712).png 3248"
Updated almost 2 years ago