home / bankproducts

Fees

One row per fee charged on a product. Every row carries a source_page reference to the original bank PDF. NULL amount means 'on request' (tailored pricing) or 'not published in current source'.

Data license: CC-BY-4.0 · Data source: bankproducts.info

5 rows where product_id = "gekb:commercial_argent" sorted by amount descending

✎ View and edit SQL

This data as json, CSV (advanced)

Suggested facets: amount, currency, frequency, valid_from (date)

id product_id bank_id fee_type label amount ▲ currency frequency tier channel note source_page valid_from access_tier
gekb:commercial_argent:annual_fee Commercial Argent (Mastercard) gekb:commercial_argent Banque Cantonale de Geneve gekb annual_fee Cotisation annuelle 85.0 CHF annual     Carte principale et chaque carte supplementaire 31 2026-01-01 free
gekb:commercial_argent:replacement Commercial Argent (Mastercard) gekb:commercial_argent Banque Cantonale de Geneve gekb card_replacement Carte de remplacement 20.0 CHF one_time       31 2026-01-01 free
gekb:commercial_argent:late_payment Commercial Argent (Mastercard) gekb:commercial_argent Banque Cantonale de Geneve gekb late_payment_fee Retard de paiement 20.0 CHF per_txn       31 2026-01-01 free
gekb:commercial_argent:cash_advance Commercial Argent (Mastercard) gekb:commercial_argent Banque Cantonale de Geneve gekb cash_advance Retrait especes 4.0 percent per_txn     4% min CHF 10, en Suisse et a l'etranger 31 2026-01-01 free
gekb:commercial_argent:fx_markup Commercial Argent (Mastercard) gekb:commercial_argent Banque Cantonale de Geneve gekb fx_markup Transactions en monnaie etrangere 1.5 percent per_txn       31 2026-01-01 free

Advanced export

JSON shape: default, array, newline-delimited, object

CSV options:

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);
Powered by Datasette · Queries took 20.586ms · Data license: CC-BY-4.0 · Data source: bankproducts.info