Fees
Data license: CC-BY-4.0 · Data source: bankproducts.info
2 rows where product_id = "dukascopy:stock_cfd" 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 |
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| dukascopy:stock_cfd:commission_ch | Single Stock CFD dukascopy:stock_cfd | Dukascopy Bank SA dukascopy | courtage | Single stock CFD commission (Switzerland) | 0.1 | percent | per_txn | CHF 0.10% of trade value, min CHF 8. Per-country schedule covers 20 markets; this row anchors the CH-market default. | 2026-05-10 | pro | |||
| dukascopy:stock_cfd:commission_us | Single Stock CFD dukascopy:stock_cfd | Dukascopy Bank SA dukascopy | courtage | Single stock CFD commission (US) | 0.02 | USD | per_txn | USD 0.02 per share, min USD 10. The only per-share (not per-percent) tier in the table — flags US stock CFDs as competitively priced for high-volume traders. | 2026-05-10 | pro |
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);