Fees
Data license: CC-BY-4.0 · Data source: bankproducts.info
2 rows where product_id = "eki:credit_gold" 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 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| eki:credit_gold:annual | Goldkarte (Viseca) eki:credit_gold | Bank EKI Genossenschaft eki | annual_fee | Erstkarte Jahresgebuehr Gold | 200.0 | CHF | annual | 7 | 2026-01-01 | free | |||
| eki:credit_gold:additional | Goldkarte (Viseca) eki:credit_gold | Bank EKI Genossenschaft eki | annual_fee_supplementary | Zusatzkarte Jahresgebuehr Gold | 50.0 | CHF | annual | 7 | 2026-01-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);