[{"data":1,"prerenderedAt":1651},["ShallowReactive",2],{"navigation":3,"examples-nav":398,"-examples-database":499,"-examples-database-surround":1648},[4,93,222,228,383,395],{"title":5,"path":6,"stem":7,"children":8,"icon":92},"","/docs","1.docs/1.index",[9,12,17,22,27,32,37,42,47,52,57,62,67,72,77,82,87],{"title":10,"path":6,"stem":7,"icon":11},"Introduction","i-lucide-compass",{"title":13,"path":14,"stem":15,"icon":16},"Quick Start","/docs/quick-start","1.docs/2.quick-start","i-lucide-zap",{"title":18,"path":19,"stem":20,"icon":21},"Renderer","/docs/renderer","1.docs/4.renderer","ri:layout-masonry-line",{"title":23,"path":24,"stem":25,"icon":26},"Routing","/docs/routing","1.docs/5.routing","ri:direction-line",{"title":28,"path":29,"stem":30,"icon":31},"Assets","/docs/assets","1.docs/50.assets","ri:image-2-line",{"title":33,"path":34,"stem":35,"icon":36},"Configuration","/docs/configuration","1.docs/50.configuration","ri:settings-3-line",{"title":38,"path":39,"stem":40,"icon":41},"Database","/docs/database","1.docs/50.database","ri:database-2-line",{"title":43,"path":44,"stem":45,"icon":46},"Lifecycle","/docs/lifecycle","1.docs/50.lifecycle","i-lucide-layers",{"title":48,"path":49,"stem":50,"icon":51},"OpenAPI","/docs/openapi","1.docs/50.openapi","ri:contract-line",{"title":53,"path":54,"stem":55,"icon":56},"Plugins","/docs/plugins","1.docs/50.plugins","ri:plug-line",{"title":58,"path":59,"stem":60,"icon":61},"Tasks","/docs/tasks","1.docs/50.tasks","codicon:run-all",{"title":63,"path":64,"stem":65,"icon":66},"WebSocket","/docs/websocket","1.docs/50.websocket","ri:broadcast-fill",{"title":68,"path":69,"stem":70,"icon":71},"Server Entry","/docs/server-entry","1.docs/6.server-entry","ri:server-line",{"title":73,"path":74,"stem":75,"icon":76},"Cache","/docs/cache","1.docs/7.cache","ri:speed-line",{"title":78,"path":79,"stem":80,"icon":81},"KV Storage","/docs/storage","1.docs/8.storage","carbon:datastore",{"title":83,"path":84,"stem":85,"icon":86},"Migration Guide","/docs/migration","1.docs/99.migration","ri:arrow-right-up-line",{"title":88,"path":89,"stem":90,"icon":91},"Nightly Channel","/docs/nightly","1.docs/99.nightly","ri:moon-fill","i-lucide-book-open",{"title":94,"path":95,"stem":96,"children":97,"icon":99},"Deploy","/deploy","2.deploy/0.index",[98,100,121],{"title":94,"path":95,"stem":96,"icon":99},"ri:upload-cloud-2-line",{"title":101,"path":102,"stem":103,"children":104,"page":120},"Runtimes","/deploy/runtimes","2.deploy/10.runtimes",[105,110,115],{"title":106,"path":107,"stem":108,"icon":109},"Node.js","/deploy/runtimes/node","2.deploy/10.runtimes/1.node","akar-icons:node-fill",{"title":111,"path":112,"stem":113,"icon":114},"Bun","/deploy/runtimes/bun","2.deploy/10.runtimes/bun","simple-icons:bun",{"title":116,"path":117,"stem":118,"icon":119},"Deno","/deploy/runtimes/deno","2.deploy/10.runtimes/deno","simple-icons:deno",false,{"title":122,"path":123,"stem":124,"children":125,"page":120},"Providers","/deploy/providers","2.deploy/20.providers",[126,130,134,138,142,146,150,154,158,162,166,170,174,178,182,186,190,194,198,202,206,210,214,218],{"title":127,"path":128,"stem":129},"Alwaysdata","/deploy/providers/alwaysdata","2.deploy/20.providers/alwaysdata",{"title":131,"path":132,"stem":133},"AWS Lambda","/deploy/providers/aws","2.deploy/20.providers/aws",{"title":135,"path":136,"stem":137},"AWS Amplify","/deploy/providers/aws-amplify","2.deploy/20.providers/aws-amplify",{"title":139,"path":140,"stem":141},"Azure","/deploy/providers/azure","2.deploy/20.providers/azure",{"title":143,"path":144,"stem":145},"Cleavr","/deploy/providers/cleavr","2.deploy/20.providers/cleavr",{"title":147,"path":148,"stem":149},"Cloudflare","/deploy/providers/cloudflare","2.deploy/20.providers/cloudflare",{"title":151,"path":152,"stem":153},"Deno Deploy","/deploy/providers/deno-deploy","2.deploy/20.providers/deno-deploy",{"title":155,"path":156,"stem":157},"DigitalOcean","/deploy/providers/digitalocean","2.deploy/20.providers/digitalocean",{"title":159,"path":160,"stem":161},"Firebase","/deploy/providers/firebase","2.deploy/20.providers/firebase",{"title":163,"path":164,"stem":165},"Flightcontrol","/deploy/providers/flightcontrol","2.deploy/20.providers/flightcontrol",{"title":167,"path":168,"stem":169},"Genezio","/deploy/providers/genezio","2.deploy/20.providers/genezio",{"title":171,"path":172,"stem":173},"GitHub Pages","/deploy/providers/github-pages","2.deploy/20.providers/github-pages",{"title":175,"path":176,"stem":177},"GitLab Pages","/deploy/providers/gitlab-pages","2.deploy/20.providers/gitlab-pages",{"title":179,"path":180,"stem":181},"Heroku","/deploy/providers/heroku","2.deploy/20.providers/heroku",{"title":183,"path":184,"stem":185},"IIS","/deploy/providers/iis","2.deploy/20.providers/iis",{"title":187,"path":188,"stem":189},"Koyeb","/deploy/providers/koyeb","2.deploy/20.providers/koyeb",{"title":191,"path":192,"stem":193},"Netlify","/deploy/providers/netlify","2.deploy/20.providers/netlify",{"title":195,"path":196,"stem":197},"Platform.sh","/deploy/providers/platform-sh","2.deploy/20.providers/platform-sh",{"title":199,"path":200,"stem":201},"Render.com","/deploy/providers/render","2.deploy/20.providers/render",{"title":203,"path":204,"stem":205},"StormKit","/deploy/providers/stormkit","2.deploy/20.providers/stormkit",{"title":207,"path":208,"stem":209},"Vercel","/deploy/providers/vercel","2.deploy/20.providers/vercel",{"title":211,"path":212,"stem":213},"Zeabur","/deploy/providers/zeabur","2.deploy/20.providers/zeabur",{"title":215,"path":216,"stem":217},"Zephyr Cloud","/deploy/providers/zephyr","2.deploy/20.providers/zephyr",{"title":219,"path":220,"stem":221},"Zerops","/deploy/providers/zerops","2.deploy/20.providers/zerops",{"title":223,"path":224,"stem":225,"children":226,"icon":36},"Config","/config","3.config/0.index",[227],{"title":223,"path":224,"stem":225,"icon":36},{"title":229,"path":230,"stem":231,"children":232,"icon":234},"Examples","/examples","4.examples/0.index",[233,235,240,245,250,255,259,264,269,274,279,284,289,293,298,302,306,311,316,321,326,331,336,341,346,351,355,360,365,369,374,379],{"title":229,"path":230,"stem":231,"icon":234},"i-lucide-folder-code",{"title":236,"path":237,"stem":238,"icon":239},"API Routes","/examples/api-routes","4.examples/api-routes","i-lucide-route",{"title":241,"path":242,"stem":243,"icon":244},"Auto Imports","/examples/auto-imports","4.examples/auto-imports","i-lucide-import",{"title":246,"path":247,"stem":248,"icon":249},"Cached Handler","/examples/cached-handler","4.examples/cached-handler","i-lucide-clock",{"title":251,"path":252,"stem":253,"icon":254},"Custom Error Handler","/examples/custom-error-handler","4.examples/custom-error-handler","i-lucide-alert-circle",{"title":38,"path":256,"stem":257,"icon":258},"/examples/database","4.examples/database","i-lucide-database",{"title":260,"path":261,"stem":262,"icon":263},"Elysia","/examples/elysia","4.examples/elysia","i-skill-icons-elysia-dark",{"title":265,"path":266,"stem":267,"icon":268},"Express","/examples/express","4.examples/express","i-simple-icons-express",{"title":270,"path":271,"stem":272,"icon":273},"Fastify","/examples/fastify","4.examples/fastify","i-simple-icons-fastify",{"title":275,"path":276,"stem":277,"icon":278},"Hello World","/examples/hello-world","4.examples/hello-world","i-lucide-sparkles",{"title":280,"path":281,"stem":282,"icon":283},"Hono","/examples/hono","4.examples/hono","i-logos-hono",{"title":285,"path":286,"stem":287,"icon":288},"Import Alias","/examples/import-alias","4.examples/import-alias","i-lucide-at-sign",{"title":290,"path":291,"stem":292,"icon":46},"Middleware","/examples/middleware","4.examples/middleware",{"title":294,"path":295,"stem":296,"icon":297},"Mono JSX","/examples/mono-jsx","4.examples/mono-jsx","i-lucide-brackets",{"title":299,"path":300,"stem":301,"icon":297},"Nano JSX","/examples/nano-jsx","4.examples/nano-jsx",{"title":53,"path":303,"stem":304,"icon":305},"/examples/plugins","4.examples/plugins","i-lucide-plug",{"title":307,"path":308,"stem":309,"icon":310},"Custom Renderer","/examples/renderer","4.examples/renderer","i-lucide-code",{"title":312,"path":313,"stem":314,"icon":315},"Runtime Config","/examples/runtime-config","4.examples/runtime-config","i-lucide-settings",{"title":317,"path":318,"stem":319,"icon":320},"Server Fetch","/examples/server-fetch","4.examples/server-fetch","i-lucide-arrow-right-left",{"title":322,"path":323,"stem":324,"icon":325},"Shiki","/examples/shiki","4.examples/shiki","i-lucide-highlighter",{"title":327,"path":328,"stem":329,"icon":330},"Virtual Routes","/examples/virtual-routes","4.examples/virtual-routes","i-lucide-box",{"title":332,"path":333,"stem":334,"icon":335},"Vite Nitro Plugin","/examples/vite-nitro-plugin","4.examples/vite-nitro-plugin","i-logos-vitejs",{"title":337,"path":338,"stem":339,"icon":340},"Vite RSC","/examples/vite-rsc","4.examples/vite-rsc","i-logos-react",{"title":342,"path":343,"stem":344,"icon":345},"Vite SSR HTML","/examples/vite-ssr-html","4.examples/vite-ssr-html","i-logos-html-5",{"title":347,"path":348,"stem":349,"icon":350},"SSR with Preact","/examples/vite-ssr-preact","4.examples/vite-ssr-preact","i-logos-preact",{"title":352,"path":353,"stem":354,"icon":340},"SSR with React","/examples/vite-ssr-react","4.examples/vite-ssr-react",{"title":356,"path":357,"stem":358,"icon":359},"SSR with SolidJS","/examples/vite-ssr-solid","4.examples/vite-ssr-solid","i-logos-solidjs-icon",{"title":361,"path":362,"stem":363,"icon":364},"SSR with TanStack Router","/examples/vite-ssr-tsr-react","4.examples/vite-ssr-tsr-react","i-simple-icons-tanstack",{"title":366,"path":367,"stem":368,"icon":364},"SSR with TanStack Start","/examples/vite-ssr-tss-react","4.examples/vite-ssr-tss-react",{"title":370,"path":371,"stem":372,"icon":373},"SSR with Vue Router","/examples/vite-ssr-vue-router","4.examples/vite-ssr-vue-router","i-logos-vue",{"title":375,"path":376,"stem":377,"icon":378},"Vite + tRPC","/examples/vite-trpc","4.examples/vite-trpc","i-simple-icons-trpc",{"title":63,"path":380,"stem":381,"icon":382},"/examples/websocket","4.examples/websocket","i-lucide-radio",{"title":384,"path":385,"stem":386,"children":387},"Blog","/blog","9.blog",[388,391],{"title":384,"path":385,"stem":389,"icon":390},"9.blog/index","i-lucide-file-text",{"title":392,"path":393,"stem":394,"icon":390},"Nitro v3 Beta is here!","/blog/v3-beta","9.blog/1.v3-beta",{"title":5,"path":396,"stem":397},"/","index",[399,404,408,411,414,417,421,424,427,430,433,436,439,443,446,449,452,455,458,462,465,469,472,475,478,481,484,487,490,493,496],{"title":236,"description":400,"meta":401,"path":237},"File-based API routing with HTTP method support and dynamic parameters.",{"automd":402,"category":403,"icon":239},true,"features",{"title":241,"description":405,"meta":406,"path":242},"Automatic imports for utilities and composables.",{"automd":402,"category":407,"icon":244},"config",{"title":246,"description":409,"meta":410,"path":247},"Cache route responses with configurable bypass logic.",{"automd":402,"category":403,"icon":249},{"title":251,"description":412,"meta":413,"path":252},"Customize error responses with a global error handler.",{"automd":402,"category":403,"icon":254},{"title":38,"description":415,"meta":416,"path":256},"Built-in database support with SQL template literals.",{"automd":402,"category":403,"icon":258},{"title":260,"description":418,"meta":419,"path":261},"Integrate Elysia with Nitro using the server entry.",{"automd":402,"category":420,"icon":263},"backend frameworks",{"title":265,"description":422,"meta":423,"path":266},"Integrate Express with Nitro using the server entry.",{"automd":402,"category":420,"icon":268},{"title":270,"description":425,"meta":426,"path":271},"Integrate Fastify with Nitro using the server entry.",{"automd":402,"category":420,"icon":273},{"title":275,"description":428,"meta":429,"path":276},"Minimal Nitro server using the web standard fetch handler.",{"automd":402,"category":403,"icon":278},{"title":280,"description":431,"meta":432,"path":281},"Integrate Hono with Nitro using the server entry.",{"automd":402,"category":420,"icon":283},{"title":285,"description":434,"meta":435,"path":286},"Custom import aliases for cleaner module paths.",{"automd":402,"category":407,"icon":288},{"title":290,"description":437,"meta":438,"path":291},"Request middleware for authentication, logging, and request modification.",{"automd":402,"category":403,"icon":46},{"title":294,"description":440,"meta":441,"path":295},"Server-side JSX rendering in Nitro with mono-jsx.",{"automd":402,"category":442,"icon":297},"server side rendering",{"title":299,"description":444,"meta":445,"path":300},"Server-side JSX rendering in Nitro with nano-jsx.",{"automd":402,"category":442,"icon":297},{"title":53,"description":447,"meta":448,"path":303},"Extend Nitro with custom plugins for hooks and lifecycle events.",{"automd":402,"category":403,"icon":305},{"title":307,"description":450,"meta":451,"path":308},"Build a custom HTML renderer in Nitro with server-side data fetching.",{"automd":402,"category":442,"icon":310},{"title":312,"description":453,"meta":454,"path":313},"Environment-aware configuration with runtime access.",{"automd":402,"category":407,"icon":315},{"title":317,"description":456,"meta":457,"path":318},"Internal server-to-server requests without network overhead.",{"automd":402,"category":403,"icon":320},{"title":322,"description":459,"meta":460,"path":323},"Server-side syntax highlighting in Nitro with Shiki.",{"automd":402,"category":461,"icon":325},"integrations",{"title":327,"description":463,"meta":464,"path":328},"Define routes programmatically using Nitro's virtual module system.",{"automd":402,"category":403,"icon":330},{"title":332,"description":466,"meta":467,"path":333},"Use Nitro as a Vite plugin for programmatic configuration.",{"automd":402,"category":468,"icon":335},"vite",{"title":337,"description":470,"meta":471,"path":338},"React Server Components with Vite and Nitro.",{"automd":402,"category":468,"icon":340},{"title":342,"description":473,"meta":474,"path":343},"Server-side rendering with vanilla HTML, Vite, and Nitro.",{"automd":402,"category":442,"icon":345},{"title":347,"description":476,"meta":477,"path":348},"Server-side rendering with Preact in Nitro using Vite.",{"automd":402,"category":442,"icon":350},{"title":352,"description":479,"meta":480,"path":353},"Server-side rendering with React in Nitro using Vite.",{"automd":402,"category":442,"icon":340},{"title":356,"description":482,"meta":483,"path":357},"Server-side rendering with SolidJS in Nitro using Vite.",{"automd":402,"category":442,"icon":359},{"title":361,"description":485,"meta":486,"path":362},"Client-side routing with TanStack Router in Nitro using Vite.",{"automd":402,"category":442,"icon":364},{"title":366,"description":488,"meta":489,"path":367},"Full-stack React with TanStack Start in Nitro using Vite.",{"automd":402,"category":442,"icon":364},{"title":370,"description":491,"meta":492,"path":371},"Server-side rendering with Vue Router in Nitro using Vite.",{"automd":402,"category":442,"icon":373},{"title":375,"description":494,"meta":495,"path":376},"End-to-end typesafe APIs with tRPC in Nitro using Vite.",{"automd":402,"category":468,"icon":378},{"title":63,"description":497,"meta":498,"path":380},"Real-time bidirectional communication with WebSocket support.",{"automd":402,"category":403,"icon":382},{"id":500,"title":38,"body":501,"description":415,"extension":1643,"meta":1644,"navigation":1645,"path":256,"seo":1646,"stem":257,"__hash__":1647},"content/4.examples/database.md",{"type":502,"value":503,"toc":1638,"icon":258},"minimark",[504,1226,1230,1235,1435,1450,1454,1461,1617,1621,1634],[505,506,509,627,714,970,994,1048],"code-tree",{":expand-all":507,"default-value":508},"true","server.ts",[510,511,516],"pre",{"className":512,"code":513,"filename":514,"language":515,"meta":5,"style":5},"language-ts shiki shiki-themes github-light github-dark github-dark","import { defineConfig } from \"nitro\";\n\nexport default defineConfig({\n  experimental: {\n    database: true,\n    tasks: true,\n  },\n  database: {\n    default: { connector: \"sqlite\" },\n  },\n});\n","nitro.config.ts","ts",[517,518,519,542,548,564,570,582,592,598,604,616,621],"code",{"__ignoreMap":5},[520,521,524,528,532,535,539],"span",{"class":522,"line":523},"line",1,[520,525,527],{"class":526},"so5gQ","import",[520,529,531],{"class":530},"slsVL"," { defineConfig } ",[520,533,534],{"class":526},"from",[520,536,538],{"class":537},"sfrk1"," \"nitro\"",[520,540,541],{"class":530},";\n",[520,543,545],{"class":522,"line":544},2,[520,546,547],{"emptyLinePlaceholder":402},"\n",[520,549,551,554,557,561],{"class":522,"line":550},3,[520,552,553],{"class":526},"export",[520,555,556],{"class":526}," default",[520,558,560],{"class":559},"shcOC"," defineConfig",[520,562,563],{"class":530},"({\n",[520,565,567],{"class":522,"line":566},4,[520,568,569],{"class":530},"  experimental: {\n",[520,571,573,576,579],{"class":522,"line":572},5,[520,574,575],{"class":530},"    database: ",[520,577,507],{"class":578},"suiK_",[520,580,581],{"class":530},",\n",[520,583,585,588,590],{"class":522,"line":584},6,[520,586,587],{"class":530},"    tasks: ",[520,589,507],{"class":578},[520,591,581],{"class":530},[520,593,595],{"class":522,"line":594},7,[520,596,597],{"class":530},"  },\n",[520,599,601],{"class":522,"line":600},8,[520,602,603],{"class":530},"  database: {\n",[520,605,607,610,613],{"class":522,"line":606},9,[520,608,609],{"class":530},"    default: { connector: ",[520,611,612],{"class":537},"\"sqlite\"",[520,614,615],{"class":530}," },\n",[520,617,619],{"class":522,"line":618},10,[520,620,597],{"class":530},[520,622,624],{"class":522,"line":623},11,[520,625,626],{"class":530},"});\n",[510,628,633],{"className":629,"code":630,"filename":631,"language":632,"meta":5,"style":5},"language-json shiki shiki-themes github-light github-dark github-dark","{\n  \"type\": \"module\",\n  \"scripts\": {\n    \"dev\": \"nitro dev\",\n    \"build\": \"nitro build\"\n  },\n  \"devDependencies\": {\n    \"nitro\": \"latest\"\n  }\n}\n","package.json","json",[517,634,635,640,653,661,673,683,687,694,704,709],{"__ignoreMap":5},[520,636,637],{"class":522,"line":523},[520,638,639],{"class":530},"{\n",[520,641,642,645,648,651],{"class":522,"line":544},[520,643,644],{"class":578},"  \"type\"",[520,646,647],{"class":530},": ",[520,649,650],{"class":537},"\"module\"",[520,652,581],{"class":530},[520,654,655,658],{"class":522,"line":550},[520,656,657],{"class":578},"  \"scripts\"",[520,659,660],{"class":530},": {\n",[520,662,663,666,668,671],{"class":522,"line":566},[520,664,665],{"class":578},"    \"dev\"",[520,667,647],{"class":530},[520,669,670],{"class":537},"\"nitro dev\"",[520,672,581],{"class":530},[520,674,675,678,680],{"class":522,"line":572},[520,676,677],{"class":578},"    \"build\"",[520,679,647],{"class":530},[520,681,682],{"class":537},"\"nitro build\"\n",[520,684,685],{"class":522,"line":584},[520,686,597],{"class":530},[520,688,689,692],{"class":522,"line":594},[520,690,691],{"class":578},"  \"devDependencies\"",[520,693,660],{"class":530},[520,695,696,699,701],{"class":522,"line":600},[520,697,698],{"class":578},"    \"nitro\"",[520,700,647],{"class":530},[520,702,703],{"class":537},"\"latest\"\n",[520,705,706],{"class":522,"line":606},[520,707,708],{"class":530},"  }\n",[520,710,711],{"class":522,"line":618},[520,712,713],{"class":530},"}\n",[510,715,717],{"className":512,"code":716,"filename":508,"language":515,"meta":5,"style":5},"import { defineHandler } from \"nitro\";\nimport { useDatabase } from \"nitro/database\";\n\nexport default defineHandler(async () => {\n  const db = useDatabase();\n\n  // Create users table\n  await db.sql`DROP TABLE IF EXISTS users`;\n  await db.sql`CREATE TABLE IF NOT EXISTS users (\"id\" TEXT PRIMARY KEY, \"firstName\" TEXT, \"lastName\" TEXT, \"email\" TEXT)`;\n\n  // Add a new user\n  const userId = String(Math.round(Math.random() * 10_000));\n  await db.sql`INSERT INTO users VALUES (${userId}, 'John', 'Doe', '')`;\n\n  // Query for users\n  const { rows } = await db.sql`SELECT * FROM users WHERE id = ${userId}`;\n\n  return {\n    rows,\n  };\n});\n",[517,718,719,732,746,750,774,791,795,801,817,830,834,839,875,895,900,906,940,945,953,959,965],{"__ignoreMap":5},[520,720,721,723,726,728,730],{"class":522,"line":523},[520,722,527],{"class":526},[520,724,725],{"class":530}," { defineHandler } ",[520,727,534],{"class":526},[520,729,538],{"class":537},[520,731,541],{"class":530},[520,733,734,736,739,741,744],{"class":522,"line":544},[520,735,527],{"class":526},[520,737,738],{"class":530}," { useDatabase } ",[520,740,534],{"class":526},[520,742,743],{"class":537}," \"nitro/database\"",[520,745,541],{"class":530},[520,747,748],{"class":522,"line":550},[520,749,547],{"emptyLinePlaceholder":402},[520,751,752,754,756,759,762,765,768,771],{"class":522,"line":566},[520,753,553],{"class":526},[520,755,556],{"class":526},[520,757,758],{"class":559}," defineHandler",[520,760,761],{"class":530},"(",[520,763,764],{"class":526},"async",[520,766,767],{"class":530}," () ",[520,769,770],{"class":526},"=>",[520,772,773],{"class":530}," {\n",[520,775,776,779,782,785,788],{"class":522,"line":572},[520,777,778],{"class":526},"  const",[520,780,781],{"class":578}," db",[520,783,784],{"class":526}," =",[520,786,787],{"class":559}," useDatabase",[520,789,790],{"class":530},"();\n",[520,792,793],{"class":522,"line":584},[520,794,547],{"emptyLinePlaceholder":402},[520,796,797],{"class":522,"line":594},[520,798,800],{"class":799},"sCsY4","  // Create users table\n",[520,802,803,806,809,812,815],{"class":522,"line":600},[520,804,805],{"class":526},"  await",[520,807,808],{"class":530}," db.",[520,810,811],{"class":559},"sql",[520,813,814],{"class":537},"`DROP TABLE IF EXISTS users`",[520,816,541],{"class":530},[520,818,819,821,823,825,828],{"class":522,"line":606},[520,820,805],{"class":526},[520,822,808],{"class":530},[520,824,811],{"class":559},[520,826,827],{"class":537},"`CREATE TABLE IF NOT EXISTS users (\"id\" TEXT PRIMARY KEY, \"firstName\" TEXT, \"lastName\" TEXT, \"email\" TEXT)`",[520,829,541],{"class":530},[520,831,832],{"class":522,"line":618},[520,833,547],{"emptyLinePlaceholder":402},[520,835,836],{"class":522,"line":623},[520,837,838],{"class":799},"  // Add a new user\n",[520,840,842,844,847,849,852,855,858,860,863,866,869,872],{"class":522,"line":841},12,[520,843,778],{"class":526},[520,845,846],{"class":578}," userId",[520,848,784],{"class":526},[520,850,851],{"class":559}," String",[520,853,854],{"class":530},"(Math.",[520,856,857],{"class":559},"round",[520,859,854],{"class":530},[520,861,862],{"class":559},"random",[520,864,865],{"class":530},"() ",[520,867,868],{"class":526},"*",[520,870,871],{"class":578}," 10_000",[520,873,874],{"class":530},"));\n",[520,876,878,880,882,884,887,890,893],{"class":522,"line":877},13,[520,879,805],{"class":526},[520,881,808],{"class":530},[520,883,811],{"class":559},[520,885,886],{"class":537},"`INSERT INTO users VALUES (${",[520,888,889],{"class":530},"userId",[520,891,892],{"class":537},"}, 'John', 'Doe', '')`",[520,894,541],{"class":530},[520,896,898],{"class":522,"line":897},14,[520,899,547],{"emptyLinePlaceholder":402},[520,901,903],{"class":522,"line":902},15,[520,904,905],{"class":799},"  // Query for users\n",[520,907,909,911,914,917,920,923,926,928,930,933,935,938],{"class":522,"line":908},16,[520,910,778],{"class":526},[520,912,913],{"class":530}," { ",[520,915,916],{"class":578},"rows",[520,918,919],{"class":530}," } ",[520,921,922],{"class":526},"=",[520,924,925],{"class":526}," await",[520,927,808],{"class":530},[520,929,811],{"class":559},[520,931,932],{"class":537},"`SELECT * FROM users WHERE id = ${",[520,934,889],{"class":530},[520,936,937],{"class":537},"}`",[520,939,541],{"class":530},[520,941,943],{"class":522,"line":942},17,[520,944,547],{"emptyLinePlaceholder":402},[520,946,948,951],{"class":522,"line":947},18,[520,949,950],{"class":526},"  return",[520,952,773],{"class":530},[520,954,956],{"class":522,"line":955},19,[520,957,958],{"class":530},"    rows,\n",[520,960,962],{"class":522,"line":961},20,[520,963,964],{"class":530},"  };\n",[520,966,968],{"class":522,"line":967},21,[520,969,626],{"class":530},[510,971,974],{"className":629,"code":972,"filename":973,"language":632,"meta":5,"style":5},"{\n  \"extends\": \"nitro/tsconfig\"\n}\n","tsconfig.json",[517,975,976,980,990],{"__ignoreMap":5},[520,977,978],{"class":522,"line":523},[520,979,639],{"class":530},[520,981,982,985,987],{"class":522,"line":544},[520,983,984],{"class":578},"  \"extends\"",[520,986,647],{"class":530},[520,988,989],{"class":537},"\"nitro/tsconfig\"\n",[520,991,992],{"class":522,"line":550},[520,993,713],{"class":530},[510,995,998],{"className":512,"code":996,"filename":997,"language":515,"meta":5,"style":5},"import { defineConfig } from \"vite\";\nimport { nitro } from \"nitro/vite\";\n\nexport default defineConfig({ plugins: [nitro()] });\n","vite.config.ts",[517,999,1000,1013,1027,1031],{"__ignoreMap":5},[520,1001,1002,1004,1006,1008,1011],{"class":522,"line":523},[520,1003,527],{"class":526},[520,1005,531],{"class":530},[520,1007,534],{"class":526},[520,1009,1010],{"class":537}," \"vite\"",[520,1012,541],{"class":530},[520,1014,1015,1017,1020,1022,1025],{"class":522,"line":544},[520,1016,527],{"class":526},[520,1018,1019],{"class":530}," { nitro } ",[520,1021,534],{"class":526},[520,1023,1024],{"class":537}," \"nitro/vite\"",[520,1026,541],{"class":530},[520,1028,1029],{"class":522,"line":550},[520,1030,547],{"emptyLinePlaceholder":402},[520,1032,1033,1035,1037,1039,1042,1045],{"class":522,"line":566},[520,1034,553],{"class":526},[520,1036,556],{"class":526},[520,1038,560],{"class":559},[520,1040,1041],{"class":530},"({ plugins: [",[520,1043,1044],{"class":559},"nitro",[520,1046,1047],{"class":530},"()] });\n",[510,1049,1052],{"className":512,"code":1050,"filename":1051,"language":515,"meta":5,"style":5},"import { defineTask } from \"nitro/task\";\nimport { useDatabase } from \"nitro/database\";\n\nexport default defineTask({\n  meta: {\n    description: \"Run database migrations\",\n  },\n  async run() {\n    const db = useDatabase();\n\n    console.log(\"Running database migrations...\");\n\n    // Create users table\n    await db.sql`DROP TABLE IF EXISTS users`;\n    await db.sql`CREATE TABLE IF NOT EXISTS users (\"id\" TEXT PRIMARY KEY, \"firstName\" TEXT, \"lastName\" TEXT, \"email\" TEXT)`;\n\n    return {\n      result: \"Database migrations complete!\",\n    };\n  },\n});\n","tasks/db/migrate.ts",[517,1053,1054,1068,1080,1084,1095,1100,1110,1114,1125,1138,1142,1158,1162,1167,1180,1192,1196,1203,1213,1218,1222],{"__ignoreMap":5},[520,1055,1056,1058,1061,1063,1066],{"class":522,"line":523},[520,1057,527],{"class":526},[520,1059,1060],{"class":530}," { defineTask } ",[520,1062,534],{"class":526},[520,1064,1065],{"class":537}," \"nitro/task\"",[520,1067,541],{"class":530},[520,1069,1070,1072,1074,1076,1078],{"class":522,"line":544},[520,1071,527],{"class":526},[520,1073,738],{"class":530},[520,1075,534],{"class":526},[520,1077,743],{"class":537},[520,1079,541],{"class":530},[520,1081,1082],{"class":522,"line":550},[520,1083,547],{"emptyLinePlaceholder":402},[520,1085,1086,1088,1090,1093],{"class":522,"line":566},[520,1087,553],{"class":526},[520,1089,556],{"class":526},[520,1091,1092],{"class":559}," defineTask",[520,1094,563],{"class":530},[520,1096,1097],{"class":522,"line":572},[520,1098,1099],{"class":530},"  meta: {\n",[520,1101,1102,1105,1108],{"class":522,"line":584},[520,1103,1104],{"class":530},"    description: ",[520,1106,1107],{"class":537},"\"Run database migrations\"",[520,1109,581],{"class":530},[520,1111,1112],{"class":522,"line":594},[520,1113,597],{"class":530},[520,1115,1116,1119,1122],{"class":522,"line":600},[520,1117,1118],{"class":526},"  async",[520,1120,1121],{"class":559}," run",[520,1123,1124],{"class":530},"() {\n",[520,1126,1127,1130,1132,1134,1136],{"class":522,"line":606},[520,1128,1129],{"class":526},"    const",[520,1131,781],{"class":578},[520,1133,784],{"class":526},[520,1135,787],{"class":559},[520,1137,790],{"class":530},[520,1139,1140],{"class":522,"line":618},[520,1141,547],{"emptyLinePlaceholder":402},[520,1143,1144,1147,1150,1152,1155],{"class":522,"line":623},[520,1145,1146],{"class":530},"    console.",[520,1148,1149],{"class":559},"log",[520,1151,761],{"class":530},[520,1153,1154],{"class":537},"\"Running database migrations...\"",[520,1156,1157],{"class":530},");\n",[520,1159,1160],{"class":522,"line":841},[520,1161,547],{"emptyLinePlaceholder":402},[520,1163,1164],{"class":522,"line":877},[520,1165,1166],{"class":799},"    // Create users table\n",[520,1168,1169,1172,1174,1176,1178],{"class":522,"line":897},[520,1170,1171],{"class":526},"    await",[520,1173,808],{"class":530},[520,1175,811],{"class":559},[520,1177,814],{"class":537},[520,1179,541],{"class":530},[520,1181,1182,1184,1186,1188,1190],{"class":522,"line":902},[520,1183,1171],{"class":526},[520,1185,808],{"class":530},[520,1187,811],{"class":559},[520,1189,827],{"class":537},[520,1191,541],{"class":530},[520,1193,1194],{"class":522,"line":908},[520,1195,547],{"emptyLinePlaceholder":402},[520,1197,1198,1201],{"class":522,"line":942},[520,1199,1200],{"class":526},"    return",[520,1202,773],{"class":530},[520,1204,1205,1208,1211],{"class":522,"line":947},[520,1206,1207],{"class":530},"      result: ",[520,1209,1210],{"class":537},"\"Database migrations complete!\"",[520,1212,581],{"class":530},[520,1214,1215],{"class":522,"line":955},[520,1216,1217],{"class":530},"    };\n",[520,1219,1220],{"class":522,"line":961},[520,1221,597],{"class":530},[520,1223,1224],{"class":522,"line":967},[520,1225,626],{"class":530},[1227,1228,1229],"p",{},"Nitro provides a built-in database layer that uses SQL template literals for safe, parameterized queries. This example creates a users table, inserts a record, and queries it back.",[1231,1232,1234],"h2",{"id":1233},"querying-the-database","Querying the Database",[510,1236,1237],{"className":512,"code":716,"filename":508,"language":515,"meta":5,"style":5},[517,1238,1239,1251,1263,1267,1285,1297,1301,1305,1317,1329,1333,1337,1363,1379,1383,1387,1413,1417,1423,1427,1431],{"__ignoreMap":5},[520,1240,1241,1243,1245,1247,1249],{"class":522,"line":523},[520,1242,527],{"class":526},[520,1244,725],{"class":530},[520,1246,534],{"class":526},[520,1248,538],{"class":537},[520,1250,541],{"class":530},[520,1252,1253,1255,1257,1259,1261],{"class":522,"line":544},[520,1254,527],{"class":526},[520,1256,738],{"class":530},[520,1258,534],{"class":526},[520,1260,743],{"class":537},[520,1262,541],{"class":530},[520,1264,1265],{"class":522,"line":550},[520,1266,547],{"emptyLinePlaceholder":402},[520,1268,1269,1271,1273,1275,1277,1279,1281,1283],{"class":522,"line":566},[520,1270,553],{"class":526},[520,1272,556],{"class":526},[520,1274,758],{"class":559},[520,1276,761],{"class":530},[520,1278,764],{"class":526},[520,1280,767],{"class":530},[520,1282,770],{"class":526},[520,1284,773],{"class":530},[520,1286,1287,1289,1291,1293,1295],{"class":522,"line":572},[520,1288,778],{"class":526},[520,1290,781],{"class":578},[520,1292,784],{"class":526},[520,1294,787],{"class":559},[520,1296,790],{"class":530},[520,1298,1299],{"class":522,"line":584},[520,1300,547],{"emptyLinePlaceholder":402},[520,1302,1303],{"class":522,"line":594},[520,1304,800],{"class":799},[520,1306,1307,1309,1311,1313,1315],{"class":522,"line":600},[520,1308,805],{"class":526},[520,1310,808],{"class":530},[520,1312,811],{"class":559},[520,1314,814],{"class":537},[520,1316,541],{"class":530},[520,1318,1319,1321,1323,1325,1327],{"class":522,"line":606},[520,1320,805],{"class":526},[520,1322,808],{"class":530},[520,1324,811],{"class":559},[520,1326,827],{"class":537},[520,1328,541],{"class":530},[520,1330,1331],{"class":522,"line":618},[520,1332,547],{"emptyLinePlaceholder":402},[520,1334,1335],{"class":522,"line":623},[520,1336,838],{"class":799},[520,1338,1339,1341,1343,1345,1347,1349,1351,1353,1355,1357,1359,1361],{"class":522,"line":841},[520,1340,778],{"class":526},[520,1342,846],{"class":578},[520,1344,784],{"class":526},[520,1346,851],{"class":559},[520,1348,854],{"class":530},[520,1350,857],{"class":559},[520,1352,854],{"class":530},[520,1354,862],{"class":559},[520,1356,865],{"class":530},[520,1358,868],{"class":526},[520,1360,871],{"class":578},[520,1362,874],{"class":530},[520,1364,1365,1367,1369,1371,1373,1375,1377],{"class":522,"line":877},[520,1366,805],{"class":526},[520,1368,808],{"class":530},[520,1370,811],{"class":559},[520,1372,886],{"class":537},[520,1374,889],{"class":530},[520,1376,892],{"class":537},[520,1378,541],{"class":530},[520,1380,1381],{"class":522,"line":897},[520,1382,547],{"emptyLinePlaceholder":402},[520,1384,1385],{"class":522,"line":902},[520,1386,905],{"class":799},[520,1388,1389,1391,1393,1395,1397,1399,1401,1403,1405,1407,1409,1411],{"class":522,"line":908},[520,1390,778],{"class":526},[520,1392,913],{"class":530},[520,1394,916],{"class":578},[520,1396,919],{"class":530},[520,1398,922],{"class":526},[520,1400,925],{"class":526},[520,1402,808],{"class":530},[520,1404,811],{"class":559},[520,1406,932],{"class":537},[520,1408,889],{"class":530},[520,1410,937],{"class":537},[520,1412,541],{"class":530},[520,1414,1415],{"class":522,"line":942},[520,1416,547],{"emptyLinePlaceholder":402},[520,1418,1419,1421],{"class":522,"line":947},[520,1420,950],{"class":526},[520,1422,773],{"class":530},[520,1424,1425],{"class":522,"line":955},[520,1426,958],{"class":530},[520,1428,1429],{"class":522,"line":961},[520,1430,964],{"class":530},[520,1432,1433],{"class":522,"line":967},[520,1434,626],{"class":530},[1227,1436,1437,1438,1441,1442,1445,1446,1449],{},"Retrieve the database instance using ",[517,1439,1440],{},"useDatabase()",". The database can be queried using ",[517,1443,1444],{},"db.sql",", and variables like ",[517,1447,1448],{},"${userId}"," are automatically escaped to prevent SQL injection.",[1231,1451,1453],{"id":1452},"running-migrations-with-tasks","Running Migrations with Tasks",[1227,1455,1456,1457,1460],{},"Nitro tasks let you run operations outside of request handlers. For database migrations, create a task file in ",[517,1458,1459],{},"tasks/"," and run it via the CLI. This keeps schema changes separate from your application code.",[510,1462,1463],{"className":512,"code":1050,"filename":1051,"language":515,"meta":5,"style":5},[517,1464,1465,1477,1489,1493,1503,1507,1515,1519,1527,1539,1543,1555,1559,1563,1575,1587,1591,1597,1605,1609,1613],{"__ignoreMap":5},[520,1466,1467,1469,1471,1473,1475],{"class":522,"line":523},[520,1468,527],{"class":526},[520,1470,1060],{"class":530},[520,1472,534],{"class":526},[520,1474,1065],{"class":537},[520,1476,541],{"class":530},[520,1478,1479,1481,1483,1485,1487],{"class":522,"line":544},[520,1480,527],{"class":526},[520,1482,738],{"class":530},[520,1484,534],{"class":526},[520,1486,743],{"class":537},[520,1488,541],{"class":530},[520,1490,1491],{"class":522,"line":550},[520,1492,547],{"emptyLinePlaceholder":402},[520,1494,1495,1497,1499,1501],{"class":522,"line":566},[520,1496,553],{"class":526},[520,1498,556],{"class":526},[520,1500,1092],{"class":559},[520,1502,563],{"class":530},[520,1504,1505],{"class":522,"line":572},[520,1506,1099],{"class":530},[520,1508,1509,1511,1513],{"class":522,"line":584},[520,1510,1104],{"class":530},[520,1512,1107],{"class":537},[520,1514,581],{"class":530},[520,1516,1517],{"class":522,"line":594},[520,1518,597],{"class":530},[520,1520,1521,1523,1525],{"class":522,"line":600},[520,1522,1118],{"class":526},[520,1524,1121],{"class":559},[520,1526,1124],{"class":530},[520,1528,1529,1531,1533,1535,1537],{"class":522,"line":606},[520,1530,1129],{"class":526},[520,1532,781],{"class":578},[520,1534,784],{"class":526},[520,1536,787],{"class":559},[520,1538,790],{"class":530},[520,1540,1541],{"class":522,"line":618},[520,1542,547],{"emptyLinePlaceholder":402},[520,1544,1545,1547,1549,1551,1553],{"class":522,"line":623},[520,1546,1146],{"class":530},[520,1548,1149],{"class":559},[520,1550,761],{"class":530},[520,1552,1154],{"class":537},[520,1554,1157],{"class":530},[520,1556,1557],{"class":522,"line":841},[520,1558,547],{"emptyLinePlaceholder":402},[520,1560,1561],{"class":522,"line":877},[520,1562,1166],{"class":799},[520,1564,1565,1567,1569,1571,1573],{"class":522,"line":897},[520,1566,1171],{"class":526},[520,1568,808],{"class":530},[520,1570,811],{"class":559},[520,1572,814],{"class":537},[520,1574,541],{"class":530},[520,1576,1577,1579,1581,1583,1585],{"class":522,"line":902},[520,1578,1171],{"class":526},[520,1580,808],{"class":530},[520,1582,811],{"class":559},[520,1584,827],{"class":537},[520,1586,541],{"class":530},[520,1588,1589],{"class":522,"line":908},[520,1590,547],{"emptyLinePlaceholder":402},[520,1592,1593,1595],{"class":522,"line":942},[520,1594,1200],{"class":526},[520,1596,773],{"class":530},[520,1598,1599,1601,1603],{"class":522,"line":947},[520,1600,1207],{"class":530},[520,1602,1210],{"class":537},[520,1604,581],{"class":530},[520,1606,1607],{"class":522,"line":955},[520,1608,1217],{"class":530},[520,1610,1611],{"class":522,"line":961},[520,1612,597],{"class":530},[520,1614,1615],{"class":522,"line":967},[520,1616,626],{"class":530},[1231,1618,1620],{"id":1619},"learn-more","Learn More",[1622,1623,1624,1630],"ul",{},[1625,1626,1627],"li",{},[1628,1629,38],"a",{"href":39},[1625,1631,1632],{},[1628,1633,58],{"href":59},[1635,1636,1637],"style",{},"html pre.shiki code .so5gQ, html code.shiki .so5gQ{--shiki-light:#D73A49;--shiki-default:#F97583;--shiki-dark:#F97583}html pre.shiki code .slsVL, html code.shiki .slsVL{--shiki-light:#24292E;--shiki-default:#E1E4E8;--shiki-dark:#E1E4E8}html pre.shiki code .sfrk1, html code.shiki .sfrk1{--shiki-light:#032F62;--shiki-default:#9ECBFF;--shiki-dark:#9ECBFF}html pre.shiki code .shcOC, html code.shiki .shcOC{--shiki-light:#6F42C1;--shiki-default:#B392F0;--shiki-dark:#B392F0}html pre.shiki code .suiK_, html code.shiki .suiK_{--shiki-light:#005CC5;--shiki-default:#79B8FF;--shiki-dark:#79B8FF}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}",{"title":5,"searchDepth":544,"depth":544,"links":1639},[1640,1641,1642],{"id":1233,"depth":544,"text":1234},{"id":1452,"depth":544,"text":1453},{"id":1619,"depth":544,"text":1620},"md",{"automd":402,"category":403,"icon":258},{"icon":258},{"title":38,"description":415},"8l2C0v80g6mUCQbZXe2kTFLgPCI5mivFEV3pUWO2mdg",[1649,1650],{"title":251,"path":252,"stem":253,"description":412,"icon":254,"children":-1},{"title":260,"path":261,"stem":262,"description":418,"icon":263,"children":-1},1776115052125]