Fees
Data license: CC-BY-4.0 · Data source: bankproducts.info
2 rows where product_id = "hbl:travel_card" sorted by amount descending
This data as json, CSV (advanced)
Suggested facets: valid_from (date)
| id | product_id | bank_id | fee_type | label | amount ▲ | currency | frequency | tier | channel | note | source_page | valid_from | access_tier |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| hbl:travel_card:load_fee | Swiss Bankers Travel hbl:travel_card | Hypothekarbank Lenzburg AG hbl | load_fee | Aufladegebuehr | 1.5 | percent | per_txn | In der Regel 1.5% des Ladebetrags | 11 | 2026-04-01 | free | ||
| hbl:travel_card:annual_fee | Swiss Bankers Travel hbl:travel_card | Hypothekarbank Lenzburg AG hbl | annual_fee | Jahresgebuehr | 0.0 | CHF | annual | Kostenlos | 11 | 2026-04-01 | free |
Advanced export
JSON shape: default, array, newline-delimited, object
CREATE TABLE fee (
id TEXT PRIMARY KEY, -- zkb:privatkonto:account_mgmt
product_id TEXT NOT NULL REFERENCES product(id),
bank_id TEXT NOT NULL REFERENCES bank(id), -- denormalized
fee_type TEXT NOT NULL, -- standardized key
label TEXT, -- human-readable German label from PDF
amount REAL, -- NULL if text-only or varies
currency TEXT DEFAULT 'CHF', -- CHF, EUR, USD, percent
frequency TEXT, -- monthly, annual, quarterly, per_txn, one_time, per_annum_pct
tier TEXT, -- for tiered pricing: "3rd card onwards", "vol:>250k", "member"
channel TEXT, -- ebanking, paper, counter, atm, app, post_office, all
note TEXT, -- conditions, fine print
source_page INTEGER,
valid_from TEXT,
access_tier TEXT NOT NULL DEFAULT 'free' -- freemium gating; propagated from parent product
CHECK (access_tier IN ('free', 'pro', 'business'))
);
CREATE INDEX idx_fee_product ON fee(product_id);
CREATE INDEX idx_fee_bank ON fee(bank_id);
CREATE INDEX idx_fee_type ON fee(fee_type);
CREATE INDEX idx_fee_category ON fee(fee_type, bank_id);
CREATE INDEX idx_fee_access_tier ON fee(access_tier);