PostgreSQL
Database Setup
Postgres itself does not have a way of calling an external API, you will need to use a Procedural Language of your choice to create a stored procedure and call the procedure from your code.
In this showcase we will use the plpython3u language ( documentation: https://www.postgresql.org/docs/current/plpython.html ), but you can use any other supported language where you write an analogous procedure.
Bellow you can find scripts that will create the tables necessary for the purposes of this tutorial
Calling API from postgres
As we mentioned we will need to create a stored procedure using a Procedural language and compile it in Postgres. In the case of using plpython3u the procedure is as follows
We can then use this procedure to call the API inside our main block of code.
Processing the API call
Our code divides the input data into batches according to the batchSize
variable and for each of these batches call the py_pgrest
function to execute the API call. We describe the code in detail bellow, but here is the full version
Load data into JSON
To create a json structure from our input data we use two inbuilt postgres functions
JSON_BUILD_OBJECT
( [alias, columnName] , ... )creates a json object with alias as the key and columnName as value
JSON_AGG
creates an array ( used to create Bulk input )
Executing the API call
To execute the API call we simply invoke the previously created py_pgrest
function using the following code
Extracting data from the response
In our example we extract data from the API response and store it in the RESULTS table. To access the data in the response we use the following process
We use the function JSON_ARRAY_ELEMENTS twice since the strucure of the response is
This gives us a row for each result we obtained. We then take these rows ( column alias res
) and we extract the necessary values using two different operators
'- >' allows us to gain access into nested records
'- > >' extracts the final value
we then can use ::your_data_type to convert the value to the required data type
Last updated