Add your SAP Hana databases to your Linkedin Datahub!
This python package extracts views metadata from SAP Hana db to push it to Datahub. These includes:
- Table schema with datatypes
- View definitions
- View lineages with support for cross-schema references and column-level lineages
The metadata from SAP Hana are extracted and parsed using sqlalchemy (for table lineage) and sqlglot (for column lineage).
The recipe file for the source file supports ingestion of both table and column lineage via the Datahub CLI. The ingestion config file can also specify specific schemas to exclude and include, allowing for the creation of lineage across different schemas in a SAP Hana db. Results can be seen in the Datahub UI or printed in the console, or file.
Pre-built Wheels can be downloaded from the Releases page
Otherwise, you must install from source.
You need the following tools pre-installed
- Task
- Poetry
- Pyenv
- Make sure to have the required build packages installed for your OS
- And the shims for your shell
-
Clone the project
git clone git@github.com:contiamo/datahub-sap-hana.git cd datahub-sap-hana
-
You will need Python 3.10 or higher
Once you have
pyenv
and Poetry installed, you should runpyenv install 3.10.10 pyenv local 3.10.10 poetry config virtualenvs.in-project true
-
Install the project and dependencies
task setup
-
Edit the
examples/hana_recipe.yaml
to set the connection details to your SAP Hana database.If you just want to do a local test, SAP offers SAP Hana Express as a free trial version of Hana. There is also a Docker image that makes this very easy, this is our recommendation.
-
Run the test sync
poetry run datahub ingest run -c examples/hana_recipe.yaml
-
Inspect the contents of the
hana_mces.json
file that was created.
A Docker image with datahub and this package preinstalled is provided via the Github Container Registry, see here
docker run -it --rm -v `pwd`:/opt \
ghcr.io/contiamo/datahub-sap-hana:latest \
ingest run -c /opt/examples/hana_recipe.yaml
Note that you may need to set the --network
flag if you are using the Hana Express Docker image.
To run the unit tests, use
task test
To run all of the tests, just use
task test -- -v