The Analytics Toolbox for Postgres contains SQL functions. The functions are deployed in a schema called carto
inside a specific database. In Postgres, the functions can be used with tables of the same database, but different schemas.
Make sure you have installed the following tools:
make
: https://www.gnu.org/software/make/Python3
: https://www.python.org/downloads/release/python-3811 (v3.8.11)jq
: https://stedolan.github.io/jq/ (v1.6)virtualenv
: https://virtualenv.pypa.io/en/latest/ (v20.11)
The .env
file contains the variables required to deploy and run the toolbox. Replace each <template>
with your values.
# Postgres
PG_PREFIX=
PG_HOST=<host>
PG_DATABASE=<database>
PG_USER=<user>
PG_PASSWORD=<password>
common
modules
doc
: contains the functions' documentationsql
: contains the functions' SQL codetest
: contains the functions' tests
make help
: shows the commands available in the Makefilemake lint
: runs a linter (flake8) and fixes the trivial issues (brunette)make build
: builds the final SQL scriptmake deploy
: builds and deploys the SQL scripts in the Postgres databasemake test
: runs the modules tests with the Postgres database (pytest)make remove
: removes all the SQL scripts from the Postgres cluster and databasemake clean
: cleans the installed dependencies and generated files locallymake create-package
: creates the installation package in the dist folder (zip)
Make commands can be run also inside modules
folders, or be called like make ***-modules
.
Filtering
Commands build-modules
, deploy-modules
, test-modules
and create-package
can be filtered by the following. All the filters are additive:
diff
: list of changed filesmodules
: list of modules to filterfunctions
: list of functions to filter
Example:
make build-modules diff=modules/sql/quadbin/QUADBIN_RESOLUTION.sql
make deploy-modules modules=quadbin
make test-modules functions=QUADBIN_RESOLUTION
make create-package modules=quadbin