Skip to main content
Glama

notion_create_database

Create a database in Notion to organize and structure information with customizable properties and rich text formatting.

Instructions

Create a database in Notion

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
parentYesParent object of the database
titleNoTitle of database as it appears in Notion. An array of rich text objects.
propertiesYesProperty schema of database. The keys are the names of properties as they appear in Notion and the values are property schema objects.
formatNoSpecify the response format. 'json' returns the original data structure, 'markdown' returns a more readable format. Use 'markdown' when the user only needs to read the page and isn't planning to write or modify it. Use 'json' when the user needs to read the page with the intention of writing to or modifying it.markdown

Implementation Reference

  • The core handler function in NotionClientWrapper that executes the tool by sending a POST request to Notion's /databases endpoint with parent, properties, and optional title.
    async createDatabase( parent: CreateDatabaseArgs["parent"], properties: Record<string, any>, title?: RichTextItemResponse[] ): Promise<DatabaseResponse> { const body = { parent, title, properties }; const response = await fetch(`${this.baseUrl}/databases`, { method: "POST", headers: this.headers, body: JSON.stringify(body), }); return response.json(); }
  • Input schema definition for the notion_create_database tool, defining parameters like parent, title, properties.
    export const createDatabaseTool: Tool = { name: "notion_create_database", description: "Create a database in Notion", inputSchema: { type: "object", properties: { parent: { type: "object", description: "Parent object of the database", }, title: { type: "array", description: "Title of database as it appears in Notion. An array of rich text objects.", items: richTextObjectSchema, }, properties: { type: "object", description: "Property schema of database. The keys are the names of properties as they appear in Notion and the values are property schema objects.", }, format: formatParameter, }, required: ["parent", "properties"], }, };
  • Registration and dispatch in the CallToolRequest handler switch statement, casting args and calling the client handler.
    case "notion_create_database": { const args = request.params .arguments as unknown as args.CreateDatabaseArgs; response = await notionClient.createDatabase( args.parent, args.properties, args.title ); break; }
  • Tool is registered by including createDatabaseTool in the list returned by ListToolsRequest handler.
    schemas.createDatabaseTool,
  • TypeScript interface defining the arguments for createDatabase, used for type casting in the handler.
    export interface CreateDatabaseArgs { parent: { type: string; page_id?: string; database_id?: string; workspace?: boolean; }; title?: RichTextItemResponse[]; properties: Record<string, any>; format?: "json" | "markdown"; }

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/kimjungyeol/mcp-notion-server'

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