Querying data sources
Hoverfly Cloud supports data queries from a CSV Data Source for Enterprise customers to do key value data lookups and simulate persistence.
Reading from a CSV Data Source
You can read data from a CSV data source in a number of ways.
For illustration we will use this data source called "pets":
1000
birds
Archie
available
1001
dogs
Zipper
available
1002
dogs
Teddy
sold
Single value lookup with {{csv}}
The most basic query function is to return the value of one field (selected-column) given a field name to search (column-name) and a value to search for in that field (query-value). Of course the query-value would normally be pulled from the request.
Syntax:
Template Example: Display the Name of the pet with Id 1001
Output:
Retrieve all rows as a map with {{csvAsMap}}
Additional functions are available to query the CSV data source to return all or a filtered subset of it’s rows, as a map.
Retrieving the results as a map makes it simple to render back into the template, as you can use the {{this}} expression with the column names to identify which fields you want to render.
To return all the data from the csv as an array of maps. (Note that you would need to wrap this in an #each block. ) See examples below.
Syntax:
Template Example:
Output:
Retrieve filtered rows as a map with {{csvMatchingRows}}
To filter the map on a single column value at the time of query you can use csvMatchingRows. This will return all the rows where the (column-name) = (query-value)
Template Example:
Output:
Advanced querying with SQL SELECT {{csvSqlCommand}}
A simplified SQL like syntax can be used to query the data in a csv data source and retrieve a map of the results. (This syntax can also be used to UPDATE and DELETE from the data source. You cannot insert using this syntax however there is a mechanism which can be read about here.)
You can read more about using this SQL like syntax here.
Syntax:
Template Example:
Output:
Last updated