2026-05-11 00:45:43 -07:00
---
title: Building Context
2026-05-20 17:33:38 +02:00
description: Build and refresh ktx context from databases, context sources, query history, and text.
2026-05-11 00:45:43 -07:00
---
2026-05-18 09:57:27 -04:00
Build context after `ktx setup` creates `ktx.yaml` and at least one database or
2026-05-20 17:33:38 +02:00
context-source connection. **ktx** writes local semantic sources and wiki
2026-05-18 09:57:27 -04:00
pages for agents to use before writing SQL.
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
## The build loop
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
Most projects use this loop:
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
1. Check readiness with `ktx status`.
2. Build one connection with `ktx ingest <connectionId>`, or build everything
with `ktx ingest --all`.
3. Search or inspect the generated files under `semantic-layer/` and `wiki/`.
4. Edit source YAML or Markdown when business logic needs refinement.
5. Validate and query representative sources before handing the context to an
agent.
2026-05-11 00:45:43 -07:00
2026-05-18 09:57:27 -04:00
`ktx ingest --all` runs databases first, then context-source connections, so
external metadata can attach to known warehouse tables.
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
## Database ingest
2026-05-11 00:45:43 -07:00
2026-05-18 09:57:27 -04:00
Database ingest records table, column, type, constraint, and row-count context.
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
```bash
# Build one configured database connection
ktx ingest warehouse
2026-05-14 01:43:06 +02:00
# Build all configured connections
ktx ingest --all
2026-05-11 00:45:43 -07:00
```
2026-05-20 17:33:38 +02:00
Depth controls how much context **ktx** builds:
2026-05-14 18:09:26 -04:00
| Flag | Best for | What it does |
|------|----------|--------------|
2026-05-20 17:33:38 +02:00
| `--fast` | First setup, quick refreshes, CI smoke checks | Deterministic fast ingest with tables, columns, types, constraints, and row counts |
| `--deep` | Agent-ready context for real analysis | Fast ingest plus deep enrichment with descriptions, embeddings, relationship evidence, and optional query history |
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
Examples:
2026-05-11 00:45:43 -07:00
```bash
2026-05-14 18:09:26 -04:00
ktx ingest warehouse --fast
ktx ingest warehouse --deep
ktx ingest --all --deep
2026-05-11 00:45:43 -07:00
```
2026-05-18 09:57:27 -04:00
Deep ingest needs LLM and embedding readiness. Otherwise run `ktx setup` or use
`--fast`.
2026-05-14 18:09:26 -04:00
2026-05-20 17:33:38 +02:00
With `claude-code`, **ktx** agent loops can invoke only the **ktx** MCP tools for the
2026-05-18 09:57:27 -04:00
current run.
2026-05-16 12:06:34 +02:00
2026-05-14 18:09:26 -04:00
## Query history
2026-05-11 00:45:43 -07:00
2026-05-18 09:57:27 -04:00
PostgreSQL, BigQuery, and Snowflake can add query-history context: common joins,
filters, service-account patterns, redaction rules, and high-usage templates.
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
Enable it during setup, store it under `connections.<id>.context.queryHistory`,
or request it for one run:
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
```bash
ktx ingest warehouse --deep --query-history
2026-05-15 15:31:51 -04:00
# Set the lookback window for BigQuery or Snowflake query history
2026-05-14 18:09:26 -04:00
ktx ingest warehouse --query-history-window-days 30
```
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
Use `--no-query-history` when you want to skip a stored query-history setting
for one run.
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
## Relationship evidence
2026-05-11 00:45:43 -07:00
2026-05-20 17:33:38 +02:00
**ktx** scores relationship candidates during supported deep database ingest. The
2026-05-18 09:57:27 -04:00
public CLI does not expose separate relationship review subcommands.
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
## Context-source ingest
2026-05-11 00:45:43 -07:00
2026-05-18 09:57:27 -04:00
Context-source connections pull metadata from dbt, BI tools, Notion, and other
configured systems. Pass one connection id or `--all`.
2026-05-11 00:45:43 -07:00
```bash
2026-05-20 17:33:38 +02:00
# Build one context-source connection
2026-05-14 18:09:26 -04:00
ktx ingest dbt_main
2026-05-20 17:33:38 +02:00
# Build every configured database and context-source connection
2026-05-14 18:09:26 -04:00
ktx ingest --all
2026-05-11 00:45:43 -07:00
```
2026-05-14 18:09:26 -04:00
Supported source types:
| Driver | Typical source | Output |
|--------|----------------|--------|
| `dbt` | dbt project or Git repo | Semantic sources with model, column, test, tag, and description metadata |
| `metricflow` | MetricFlow project or Git repo | Metrics, dimensions, entities, and semantic joins |
| `lookml` | LookML files or Git repo | Views, explores, dimensions, measures, and joins |
| `looker` | Looker API | Explores, looks, dashboards, and model metadata |
| `metabase` | Metabase API | Questions, dashboards, table metadata, and mappings |
| `notion` | Notion API | Wiki pages and business knowledge |
2026-05-20 17:33:38 +02:00
Context-source ingest writes semantic source YAML and wiki Markdown, reconciling
with local edits.
2026-05-14 18:09:26 -04:00
## Text ingest
2026-05-20 01:52:37 +02:00
Use `ktx ingest --text` / `ktx ingest --file` for notes, Markdown, runbooks,
Slack exports, or other searchable memory.
2026-05-14 18:09:26 -04:00
```bash
# Capture a Markdown file
2026-05-20 01:52:37 +02:00
ktx ingest --file docs/revenue-notes.md --connection-id warehouse
2026-05-14 18:09:26 -04:00
# Capture one stdin item
2026-05-20 01:52:37 +02:00
printf "Refunds are excluded from net revenue." | ktx ingest --file -
2026-05-14 18:09:26 -04:00
# Capture direct text
2026-05-20 01:52:37 +02:00
ktx ingest --text "ARR excludes one-time implementation fees."
2026-05-14 18:09:26 -04:00
```
Useful flags:
2026-05-11 00:45:43 -07:00
| Flag | Description |
|------|-------------|
2026-05-20 01:52:37 +02:00
| `--text <content>` | Capture inline text into memory; repeatable |
| `--file <path>` | Capture a text file (or `-` for stdin) into memory; repeatable |
2026-05-20 17:33:38 +02:00
| `--connection-id <connectionId>` | Attach the captured memory to a **ktx** connection |
2026-05-14 18:09:26 -04:00
| `--user-id <id>` | Attribute capture to a user scope, default `local-cli` |
| `--json` | Print structured output |
2026-05-20 01:52:37 +02:00
| `--fail-fast` | Stop after the first failed text/file item |
2026-05-14 18:09:26 -04:00
2026-05-20 17:33:38 +02:00
Use text ingest for small, high-signal documents. Prefer configured context-source
2026-05-18 09:57:27 -04:00
ingest for Notion, dbt, Metabase, and similar systems.
2026-05-14 18:09:26 -04:00
## Output and artifacts
2026-05-18 09:57:27 -04:00
Every ingest run prints a summary. Use `--json` for scripts and agents.
2026-05-14 18:09:26 -04:00
```bash
ktx ingest --all --json
2026-05-11 00:45:43 -07:00
```
2026-05-14 18:09:26 -04:00
Typical generated files:
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
| Path | Created by | Purpose |
|------|------------|---------|
2026-05-20 17:33:38 +02:00
| `semantic-layer/<connection-id>/*.yaml` | Database and context-source ingest | Queryable semantic source definitions |
| `wiki/global/*.md` | Context-source, text, and memory ingest | Shared business definitions and notes |
2026-05-14 18:09:26 -04:00
| `wiki/user/<user-id>/*.md` | Text and memory ingest | User-scoped context |
| `.ktx/setup/context-build.json` | Setup context build | Resume and readiness state for setup |
2026-05-18 09:57:27 -04:00
Ingest transcripts include tool calls, LLM responses, and write decisions.
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
## Example: first full refresh
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
After interactive setup:
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
```bash
ktx status
ktx ingest --all --deep
ktx status
```
Then inspect what changed:
```bash
git status --short
2026-05-20 01:52:37 +02:00
ktx sl --json
ktx wiki "revenue" --json --limit 10
2026-05-11 00:45:43 -07:00
```
2026-05-14 18:09:26 -04:00
## Common errors
2026-05-11 00:45:43 -07:00
2026-05-14 18:09:26 -04:00
| Symptom | Likely cause | Recovery |
|---------|--------------|----------|
| Connection not configured | The connection id is missing from `ktx.yaml` | Add it with `ktx setup` |
| Deep readiness is missing | LLM or embeddings are not setup-ready | Run `ktx setup`, or rerun with `--fast` |
2026-05-20 17:33:38 +02:00
| Query history is unsupported | The selected database driver does not expose query history | Run fast ingest without query-history flags |
| No connections configured | The project has no entries under `connections` | Run `ktx setup` and add a database or context-source connection |
| Context-source flags have no effect | Depth and query-history flags were supplied for a context-source connector | Use those flags only for database connections |
2026-05-14 18:09:26 -04:00
| Text ingest stops early | `--fail-fast` stopped on the first failed item | Fix the item or rerun without `--fail-fast` |