Skip to main content
Glama
MikelA92
by MikelA92

execute_native_query

Execute custom SQL queries directly against Metabase databases to retrieve data not available through existing saved cards. Run SELECT statements to perform ad-hoc analysis and extract specific information from your database.

Instructions

⚠️ [MODERATE RISK] Execute an ad-hoc native SQL query directly against a database. Use this when you need to run custom SQL that doesn't exist as a saved card. Risk: Moderate - executes arbitrary SQL (read-only with API key, but can be slow or resource-intensive). Always validate SQL before executing.

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
databaseIdYesThe ID of the database to query
queryYesThe SQL query to execute (SELECT statements only recommended)

Implementation Reference

  • The core handler function that validates inputs, constructs a native query payload, POSTs to Metabase /api/dataset endpoint, and formats the results as MCP content.
    async executeNativeQuery(databaseId, query) { Validators.validateDatabaseId(databaseId); Validators.validateQuery(query); this.logger.debug('Executing native query', { databaseId, queryLength: query.length }); const body = { database: databaseId, type: 'native', native: { query: query, }, }; const results = await this.apiClient.makeRequest('/api/dataset', { method: 'POST', body: JSON.stringify(body), }); return { content: [ { type: 'text', text: `Query Execution Results: Database: ${databaseId} Query: ${query} Results: ${JSON.stringify(results, null, 2)}`, }, ], }; }
  • The MCP tool definition including name, description, and input schema specifying databaseId (integer) and query (string).
    { name: 'execute_native_query', description: '⚠️ [MODERATE RISK] Execute an ad-hoc native SQL query directly against a database. Use this when you need to run custom SQL that doesn\'t exist as a saved card. Risk: Moderate - executes arbitrary SQL (read-only with API key, but can be slow or resource-intensive). Always validate SQL before executing.', inputSchema: { type: 'object', properties: { databaseId: { type: 'integer', description: 'The ID of the database to query', minimum: 1, }, query: { type: 'string', description: 'The SQL query to execute (SELECT statements only recommended)', minLength: 1, }, }, required: ['databaseId', 'query'], }, },
  • Tool registration in the MCP server's executeTool switch statement, which delegates execution to the QueryHandlers instance.
    case 'execute_native_query': return await this.queryHandlers.executeNativeQuery(args.databaseId, args.query);

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/MikelA92/metabase-mcp-mab'

If you have feedback or need assistance with the MCP directory API, please join our Discord server