Load data from Personio to DuckDB¶
This guide will help you load data from Personio into DuckDB
using omniload — a simple yet powerful data loader tool.
By the end of this guide, you’ll have your Personio data securely stored in DuckDB.
Overview of omniload¶
omniload is a polyglot data loader framework and command-line tool that simplifies data ingestion by allowing users to load data from a source to a destination using simple command-line flags.
omniload Command¶
omniload ingest \
--source-uri '<your-source-uri>' \
--source-table '<your-schema>.<your-table>' \
--dest-uri '<your-destination-uri>' \
--dest-table '<your-schema>.<your-table>'
omniload ingest: Executes the data ingestion process.--source-uri TEXT: Specifies the URI of the data source.--dest-uri TEXT: Specifies the URI of the destination.--source-table TEXT: Defines the table to fetch data from.--dest-table TEXT: Specifies the destination table. If not provided, it defaults to--source-table.
With this command, we connect to the source, retrieve the specified data, and load it into the destination database.
Step-by-step instructions¶
Personio is a human resources management platform that helps businesses handle recruitment and employee data. To analyze this data, you may need to load it into an analytics database like DuckDB. omniload makes this process simple.
Step 1: Install omniload¶
Ensure omniload is installed. If not, follow the installation guide.
Step 2: Get Personio Credentials¶
Personio will be our data source.
Log in to your Personio account.
Ensure your user has API access.
Navigate to Settings > Integrations > API Credentials.
Click Generate new credentials.
Assign read access to required attributes (e.g., last name, last modified).
Copy the generated
client IDandclient secret.
For more details, refer to Personio API documentation.
Step 3: Install DuckDB¶
DuckDB will be our data destination. If it’s not already installed, you can install it using pip:
pip install duckdb
Alternatively, you can download the latest version from the official DuckDB website.
Step 4: Run the omniload Command¶
Execute the following command to load data from Personio to DuckDB:
omniload ingest \
--source-uri 'personio://?client_id=<YOUR_CLIENT_ID>&client_secret=<YOUR_CLIENT_SECRET>' \
--source-table 'employees' \
--dest-uri 'duckdb:///personio.duckdb' \
--dest-table 'dest.employees'
--source-uri 'personio://?client_id=<ID>&client_secret=<SECRET>': Connects to Personio using API credentials.--source-table 'employees': Specifies the table to fetch data from Personio.--dest-uri 'duckdb:///personio.duckdb': Specifies DuckDB as the destination database.--dest-table 'dest.employees': Defines where the data will be stored in DuckDB.
Verify Data in DuckDB¶
Once the command runs successfully, your Personio data will be available in DuckDB. Follow these steps to verify the data:
Step 1: Open DuckDB¶
If DuckDB is installed, you can open it using the following command:
duckdb personio.duckdb
Step 2: List Available Tables¶
To check if the employees table has been created, run:
.tables;
Step 3: View Data in the employees Table¶
To display all data from the employees table, run:
SELECT * FROM dest.employees;
Step 4: Validate Data¶
Ensure that the retrieved data matches what was expected from Personio.
Example output:

Congratulations¶
You have successfully loaded data from Personio to DuckDB using omniload.