home / bankproducts

Products

Retail banking products. Each row is one product offered by one bank. Categories: current_account, savings_account, pillar_3a, vested_benefits, mortgage, credit_card, debit_card, term_deposit, wealth_management, securities_trading, etc.

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

14 rows where bank_id = "swiq" sorted by bank_id descending

✎ View and edit SQL

This data as json, CSV (advanced)

Suggested facets: category, currency, client_type, target_group, access_tier

id bank_id ▲ category name currency client_type target_group description valid_from source_document_id bpg access_tier is_tailored notice_period_days iso_account_type
swiq:trading_account Swissquote Bank SA swiq self_directed_trading Swissquote Trading Account CHF private standard Self-directed Wertschriften-Konto. Multi-Waehrung. Custody-Gebuehr quartalsweise CHF 20-50 (tiered). Stock-Trading ab CHF 3.     BPG003ARRRMQ pro 0    
swiq:trading_account_corporate Swissquote Bank SA swiq self_directed_trading Swissquote Trading Account (Legal Entities) CHF business standard Wertschriften-Konto fuer juristische Personen. Custody 0.025%/Quartal, min CHF 20, kein Maximum.     BPG00366M45R pro 0    
swiq:save_easy_chf Swissquote Bank SA swiq savings_account Save Easy (CHF) CHF private standard CHF-Sparkonto. 0.10% bis CHF 100k, 0% darueber. Keine Kontofuehrungsgebuehr.     BPG0038H1799 free 0    
swiq:save_easy_eur Swissquote Bank SA swiq savings_account Save Easy (EUR) EUR private standard EUR-Sparkonto. Tiered: 0.75% bis 50k, 0.50% bis 100k, 0.25% darueber. Keine Kontofuehrung.     BPG003Z6FFAQ free 0    
swiq:save_easy_usd Swissquote Bank SA swiq savings_account Save Easy (USD) USD private standard USD-Sparkonto. Tiered: 1.75% bis 50k, 1.00% bis 100k, 0.50% darueber.     BPG003RPYQA4 free 0    
swiq:save_easy_gbp Swissquote Bank SA swiq savings_account Save Easy (GBP) GBP private standard GBP-Sparkonto. Tiered: 2.00% bis 50k, 1.25% bis 100k, 0.75% darueber. Hoechster CH-Sparzins fuer GBP-Bestaende.     BPG003JHXWFT free 0    
swiq:debit_light Swissquote Bank SA swiq debit_card Light (Virtual Debit Mastercard) CHF private standard Gratis-Virtuelle Debit Mastercard. ATM CH CHF 1.90/Bezug, Ausland CHF 4.90. FX 0.95% auf 13 Hauptwaehrungen.     BPG003NFNK1F free 0    
swiq:debit_bright Swissquote Bank SA swiq debit_card Bright (Debit Mastercard + Banking Package) CHF private standard Mittlerer Tier: CHF 6.90/Monat (erste 6 Monate gratis). 5 ATM-Bezuege CH/Monat gratis, danach CHF 1.90. ATM Ausland CHF 4.90.     BPG003STRYS7 free 0    
swiq:debit_elite Swissquote Bank SA swiq debit_card Elite (Debit Mastercard + Premium Package) CHF private wealthy Premium-Tier ab CHF 100k Vermoegen. CHF 39/Monat. 5 ATM-Bezuege CH und Ausland/Monat gratis. FX gratis bis CHF 5k/Monat, danach 0.25%.     BPG003GV0PQN free 0    
swiq:3a_easy_saving Swissquote Bank SA swiq pillar_3a 3a Easy — Saving Strategy CHF private standard Reines Cash-3a. Kostenlos. SARON-basierte Verzinsung 0.10% (Stand 2025-07-01). Min. CHF 100 pro Einzahlung.     BPG003JAQ158 pro 0    
swiq:3a_easy_balanced Swissquote Bank SA swiq pillar_3a 3a Easy — Balanced Strategy CHF private standard Ausgewogene Anlagestrategie. 0.60% all-in p.a. Min. CHF 100 pro Einzahlung.     BPG003M2DE3M pro 0    
swiq:3a_easy_dynamic Swissquote Bank SA swiq pillar_3a 3a Easy — Dynamic Strategy CHF private standard Dynamische Anlagestrategie. 0.60% all-in p.a. Min. CHF 100 pro Einzahlung.     BPG003WX7Z1P pro 0    
swiq:3a_easy_ambitious Swissquote Bank SA swiq pillar_3a 3a Easy — Ambitious Strategy CHF private standard Ambitionierte Anlagestrategie (hoechste Aktienquote). 0.60% all-in p.a. Min. CHF 100 pro Einzahlung.     BPG003Y9PK04 pro 0    
swiq:ebanking Swissquote Bank SA swiq ebanking e-Banking / Trading platform CHF private standard Web + Mobile Trading-Plattform. Kostenlos. Inklusive Online-Zahlungen CHF/EUR innerhalb CH/LI gratis.     BPG003AAWTVA free 0    

Advanced export

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

CSV options:

CREATE TABLE product (
    id                  TEXT PRIMARY KEY,  -- zkb:privatkonto, ubs:key4_banking
    bank_id             TEXT NOT NULL REFERENCES bank(id),
    category            TEXT NOT NULL,     -- current_account, savings_account, pillar_3a, vested_benefits,
                                           -- debit_card, credit_card, prepaid_card, package, ebanking,
                                           -- mortgage, wealth_management, term_deposit, securities_trading,
                                           -- fiduciary_deposit, safe_deposit, guarantee, leasing,
                                           -- financial_planning, personal_advisory, loyalty_program,
                                           -- digital_vault, fx_subscription, robo_advisory, self_directed_trading,
                                           -- metal_account, deposit_account, check
    name                TEXT NOT NULL,     -- bank's own product name
    currency            TEXT DEFAULT 'CHF',
    client_type         TEXT DEFAULT 'private',  -- private, business, institutional
    target_group        TEXT,              -- standard, young, children, students, seniors, eco, gift, rental_deposit, member
    description         TEXT,
    valid_from          TEXT,
    source_document_id  INTEGER REFERENCES source_document(id),
    bpg                 CHAR(12)        -- opaque global id, BPG003xxxxxx; populated post-load by bpg_assignments.sql
        CHECK (bpg IS NULL OR bpg GLOB 'BPG003[0-9A-HJKMNP-TV-Z][0-9A-HJKMNP-TV-Z][0-9A-HJKMNP-TV-Z][0-9A-HJKMNP-TV-Z][0-9A-HJKMNP-TV-Z][0-9A-HJKMNP-TV-Z]'),
    access_tier         TEXT NOT NULL DEFAULT 'free'  -- freemium gating: free public, pro/business paid
        CHECK (access_tier IN ('free', 'pro', 'business')),
    is_tailored         INTEGER             -- v2.6 (atom #278): mirrors CDS-AU (Australian Open Banking) isTailored.
                                            --   0 = pricing publicly published in a schedule (machine-readable, comparable);
                                            --   1 = negotiated per client (UHNW classical private banking, business loans);
                                            --   NULL = unknown / not yet classified (default for new loads).
                                            -- Distinguishes "we haven't crawled it" (NULL) from "bank deliberately
                                            -- doesn't publish because it's relationship-priced" (1) — three states
                                            -- that previously collapsed into "fee.amount IS NULL".
        CHECK (is_tailored IS NULL OR is_tailored IN (0, 1)),
    notice_period_days  INTEGER             -- v2.7 (atom #307): normalised withdrawal notice in days.
                                            --   0/NULL = on-demand; X = days notice. Conversion: months×30,
                                            --   years×365, days verbatim. Backfilled from
                                            --   product_feature.notice_period free-text by
                                            --   db/notice_period_backfill.sql.
        CHECK (notice_period_days IS NULL OR notice_period_days >= 0),
    iso_account_type    CHAR(4)             -- v2.8 (atom #308): ISO 20022 ExternalCashAccountType1Code.
                                            --   4-letter code from the official ISO enum: CACC (Current),
                                            --   SVGS (Savings), LOAN, SACC (Special), MOMA (Money Market),
                                            --   CHAR (Charges), CASH, etc.
                                            --   NULL for categories outside ISO scope: cards
                                            --   (debit/credit/prepaid), mandates (wealth_management,
                                            --   securities_trading, fiduciary_deposit), CH-specific
                                            --   (pillar_3a, vested_benefits, pension_account).
                                            --   Mapped from `category` by db/iso_account_type_backfill.sql.
                                            --   Backfill is conservative — when in doubt, leave NULL rather
                                            --   than force-fit a code that misrepresents the product.
        CHECK (iso_account_type IS NULL OR iso_account_type GLOB '[A-Z][A-Z][A-Z][A-Z]')
);
CREATE INDEX idx_product_bank ON product(bank_id);
CREATE INDEX idx_product_category ON product(category);
CREATE INDEX idx_product_lookup ON product(bank_id, category, client_type, target_group);
CREATE UNIQUE INDEX idx_product_bpg ON product(bpg) WHERE bpg IS NOT NULL;
CREATE INDEX idx_product_access_tier ON product(access_tier);
CREATE INDEX idx_product_is_tailored ON product(is_tailored) WHERE is_tailored IS NOT NULL;
CREATE INDEX idx_product_iso_account_type ON product(iso_account_type) WHERE iso_account_type IS NOT NULL;
CREATE INDEX idx_product_notice_period ON product(notice_period_days) WHERE notice_period_days IS NOT NULL;
Powered by Datasette · Queries took 27.51ms · Data license: CC-BY-4.0 · Data source: bankproducts.info