Files
fn_registry/python/functions/metabase/metabase_create_model.md
T
egutierrez cfdf515228 chore: auto-commit (799 archivos)
- .claude/CLAUDE.md
- .claude/commands/subagentes.md
- .claude/rules/INDEX.md
- .mcp.json
- bash/functions/cybersecurity/analyze_dns.md
- bash/functions/cybersecurity/audit_http_headers.md
- bash/functions/cybersecurity/audit_ssh_config.md
- bash/functions/cybersecurity/check_firewall.md
- bash/functions/cybersecurity/detect_suspicious_users.md
- bash/functions/cybersecurity/encrypt_file.md
- ...

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
2026-05-14 00:28:20 +02:00

2.3 KiB

name, kind, lang, domain, version, purity, signature, description, tags, uses_functions, uses_types, returns, returns_optional, error_type, imports, params, output, tested, tests, test_file_path, file_path
name kind lang domain version purity signature description tags uses_functions uses_types returns returns_optional error_type imports params output tested tests test_file_path file_path
metabase_create_model function py infra 1.0.0 impure def metabase_create_model(client: MetabaseClient, name: str, sql: str, database_id: int, collection_id: int = 0, description: str = '') -> dict Crea un modelo de Metabase (card con type='model') que otras cards MBQL pueden usar como fuente via source-table: 'card__<id>'.
metabase
model
card
create
api
python
pendiente-usar
false error_go_core
httpx
name desc
client instancia autenticada de MetabaseClient
name desc
name nombre del modelo
name desc
sql query SQL que define el modelo
name desc
database_id ID de la database en Metabase donde vive la query
name desc
collection_id ID de coleccion destino; 0 = root
name desc
description descripcion opcional del modelo
dict con el modelo creado: id, name, type='model', dataset_query y metadata completa false
python/functions/metabase/cards.py

Ejemplo

# Crear modelo base
model = metabase_create_model(
    client,
    name="supply_orders_base",
    sql="SELECT * FROM supply_orders WHERE status != 'cancelled'",
    database_id=6,
    collection_id=42,
    description="Ordenes de supply excluyendo canceladas",
)
print(model["id"])  # ej: 7820

# Usar el modelo como fuente en una card MBQL
card = metabase_create_card(client, "Revenue por proveedor", {
    "database": 6,
    "type": "query",
    "query": {
        "source-table": f"card__{model['id']}",
        "aggregation": [["sum", ["field", "total", None]]],
        "breakout": [["field", "supplier_id", None]],
    },
}, display="bar")

Notas

Un modelo es una card con type="model". Metabase lo trata como una capa de abstraccion — las cards MBQL que lo referencian via source-table: "card__<id>" se benefician del schema inferido del modelo (tipos de columna, foreign keys, etc.).

A diferencia de metabase_create_card, esta funcion fuerza type="model" y siempre usa query SQL nativa. Para modelos MBQL o con configuracion avanzada (result_metadata, column types), usar metabase_create_card_raw con type="model" en el payload.