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