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