[{"data":1,"prerenderedAt":1631},["ShallowReactive",2],{"navigation":3,"examples-nav":377,"-examples-database":478,"-examples-database-surround":1628},[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":1623,"meta":1624,"navigation":1625,"path":246,"seo":1626,"stem":247,"__hash__":1627},"content/4.examples/database.md",{"type":481,"value":482,"toc":1618,"icon":248},"minimark",[483,1206,1210,1215,1415,1430,1434,1441,1597,1601,1614],[484,485,488,606,693,950,974,1028],"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/h3\";\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,712,726,730,754,771,775,781,797,810,814,819,855,875,880,886,920,925,933,939,945],{"__ignoreMap":5},[499,699,700,702,705,707,710],{"class":501,"line":502},[499,701,506],{"class":505},[499,703,704],{"class":509}," { defineHandler } ",[499,706,513],{"class":505},[499,708,709],{"class":516}," \"nitro/h3\"",[499,711,520],{"class":509},[499,713,714,716,719,721,724],{"class":501,"line":523},[499,715,506],{"class":505},[499,717,718],{"class":509}," { useDatabase } ",[499,720,513],{"class":505},[499,722,723],{"class":516}," \"nitro/database\"",[499,725,520],{"class":509},[499,727,728],{"class":501,"line":529},[499,729,526],{"emptyLinePlaceholder":381},[499,731,732,734,736,739,742,745,748,751],{"class":501,"line":545},[499,733,532],{"class":505},[499,735,535],{"class":505},[499,737,738],{"class":538}," defineHandler",[499,740,741],{"class":509},"(",[499,743,744],{"class":505},"async",[499,746,747],{"class":509}," () ",[499,749,750],{"class":505},"=>",[499,752,753],{"class":509}," {\n",[499,755,756,759,762,765,768],{"class":501,"line":551},[499,757,758],{"class":505},"  const",[499,760,761],{"class":557}," db",[499,763,764],{"class":505}," =",[499,766,767],{"class":538}," useDatabase",[499,769,770],{"class":509},"();\n",[499,772,773],{"class":501,"line":563},[499,774,526],{"emptyLinePlaceholder":381},[499,776,777],{"class":501,"line":573},[499,778,780],{"class":779},"sCsY4","  // Create users table\n",[499,782,783,786,789,792,795],{"class":501,"line":579},[499,784,785],{"class":505},"  await",[499,787,788],{"class":509}," db.",[499,790,791],{"class":538},"sql",[499,793,794],{"class":516},"`DROP TABLE IF EXISTS users`",[499,796,520],{"class":509},[499,798,799,801,803,805,808],{"class":501,"line":585},[499,800,785],{"class":505},[499,802,788],{"class":509},[499,804,791],{"class":538},[499,806,807],{"class":516},"`CREATE TABLE IF NOT EXISTS users (\"id\" TEXT PRIMARY KEY, \"firstName\" TEXT, \"lastName\" TEXT, \"email\" TEXT)`",[499,809,520],{"class":509},[499,811,812],{"class":501,"line":597},[499,813,526],{"emptyLinePlaceholder":381},[499,815,816],{"class":501,"line":602},[499,817,818],{"class":779},"  // Add a new user\n",[499,820,822,824,827,829,832,835,838,840,843,846,849,852],{"class":501,"line":821},12,[499,823,758],{"class":505},[499,825,826],{"class":557}," userId",[499,828,764],{"class":505},[499,830,831],{"class":538}," String",[499,833,834],{"class":509},"(Math.",[499,836,837],{"class":538},"round",[499,839,834],{"class":509},[499,841,842],{"class":538},"random",[499,844,845],{"class":509},"() ",[499,847,848],{"class":505},"*",[499,850,851],{"class":557}," 10_000",[499,853,854],{"class":509},"));\n",[499,856,858,860,862,864,867,870,873],{"class":501,"line":857},13,[499,859,785],{"class":505},[499,861,788],{"class":509},[499,863,791],{"class":538},[499,865,866],{"class":516},"`INSERT INTO users VALUES (${",[499,868,869],{"class":509},"userId",[499,871,872],{"class":516},"}, 'John', 'Doe', '')`",[499,874,520],{"class":509},[499,876,878],{"class":501,"line":877},14,[499,879,526],{"emptyLinePlaceholder":381},[499,881,883],{"class":501,"line":882},15,[499,884,885],{"class":779},"  // Query for users\n",[499,887,889,891,894,897,900,903,906,908,910,913,915,918],{"class":501,"line":888},16,[499,890,758],{"class":505},[499,892,893],{"class":509}," { ",[499,895,896],{"class":557},"rows",[499,898,899],{"class":509}," } ",[499,901,902],{"class":505},"=",[499,904,905],{"class":505}," await",[499,907,788],{"class":509},[499,909,791],{"class":538},[499,911,912],{"class":516},"`SELECT * FROM users WHERE id = ${",[499,914,869],{"class":509},[499,916,917],{"class":516},"}`",[499,919,520],{"class":509},[499,921,923],{"class":501,"line":922},17,[499,924,526],{"emptyLinePlaceholder":381},[499,926,928,931],{"class":501,"line":927},18,[499,929,930],{"class":505},"  return",[499,932,753],{"class":509},[499,934,936],{"class":501,"line":935},19,[499,937,938],{"class":509},"    rows,\n",[499,940,942],{"class":501,"line":941},20,[499,943,944],{"class":509},"  };\n",[499,946,948],{"class":501,"line":947},21,[499,949,605],{"class":509},[489,951,954],{"className":608,"code":952,"filename":953,"language":611,"meta":5,"style":5},"{\n  \"extends\": \"nitro/tsconfig\"\n}\n","tsconfig.json",[496,955,956,960,970],{"__ignoreMap":5},[499,957,958],{"class":501,"line":502},[499,959,618],{"class":509},[499,961,962,965,967],{"class":501,"line":523},[499,963,964],{"class":557},"  \"extends\"",[499,966,626],{"class":509},[499,968,969],{"class":516},"\"nitro/tsconfig\"\n",[499,971,972],{"class":501,"line":529},[499,973,692],{"class":509},[489,975,978],{"className":491,"code":976,"filename":977,"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,979,980,993,1007,1011],{"__ignoreMap":5},[499,981,982,984,986,988,991],{"class":501,"line":502},[499,983,506],{"class":505},[499,985,510],{"class":509},[499,987,513],{"class":505},[499,989,990],{"class":516}," \"vite\"",[499,992,520],{"class":509},[499,994,995,997,1000,1002,1005],{"class":501,"line":523},[499,996,506],{"class":505},[499,998,999],{"class":509}," { nitro } ",[499,1001,513],{"class":505},[499,1003,1004],{"class":516}," \"nitro/vite\"",[499,1006,520],{"class":509},[499,1008,1009],{"class":501,"line":529},[499,1010,526],{"emptyLinePlaceholder":381},[499,1012,1013,1015,1017,1019,1022,1025],{"class":501,"line":545},[499,1014,532],{"class":505},[499,1016,535],{"class":505},[499,1018,539],{"class":538},[499,1020,1021],{"class":509},"({ plugins: [",[499,1023,1024],{"class":538},"nitro",[499,1026,1027],{"class":509},"()] });\n",[489,1029,1032],{"className":491,"code":1030,"filename":1031,"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,1033,1034,1048,1060,1064,1075,1080,1090,1094,1105,1118,1122,1138,1142,1147,1160,1172,1176,1183,1193,1198,1202],{"__ignoreMap":5},[499,1035,1036,1038,1041,1043,1046],{"class":501,"line":502},[499,1037,506],{"class":505},[499,1039,1040],{"class":509}," { defineTask } ",[499,1042,513],{"class":505},[499,1044,1045],{"class":516}," \"nitro/task\"",[499,1047,520],{"class":509},[499,1049,1050,1052,1054,1056,1058],{"class":501,"line":523},[499,1051,506],{"class":505},[499,1053,718],{"class":509},[499,1055,513],{"class":505},[499,1057,723],{"class":516},[499,1059,520],{"class":509},[499,1061,1062],{"class":501,"line":529},[499,1063,526],{"emptyLinePlaceholder":381},[499,1065,1066,1068,1070,1073],{"class":501,"line":545},[499,1067,532],{"class":505},[499,1069,535],{"class":505},[499,1071,1072],{"class":538}," defineTask",[499,1074,542],{"class":509},[499,1076,1077],{"class":501,"line":551},[499,1078,1079],{"class":509},"  meta: {\n",[499,1081,1082,1085,1088],{"class":501,"line":563},[499,1083,1084],{"class":509},"    description: ",[499,1086,1087],{"class":516},"\"Run database migrations\"",[499,1089,560],{"class":509},[499,1091,1092],{"class":501,"line":573},[499,1093,576],{"class":509},[499,1095,1096,1099,1102],{"class":501,"line":579},[499,1097,1098],{"class":505},"  async",[499,1100,1101],{"class":538}," run",[499,1103,1104],{"class":509},"() {\n",[499,1106,1107,1110,1112,1114,1116],{"class":501,"line":585},[499,1108,1109],{"class":505},"    const",[499,1111,761],{"class":557},[499,1113,764],{"class":505},[499,1115,767],{"class":538},[499,1117,770],{"class":509},[499,1119,1120],{"class":501,"line":597},[499,1121,526],{"emptyLinePlaceholder":381},[499,1123,1124,1127,1130,1132,1135],{"class":501,"line":602},[499,1125,1126],{"class":509},"    console.",[499,1128,1129],{"class":538},"log",[499,1131,741],{"class":509},[499,1133,1134],{"class":516},"\"Running database migrations...\"",[499,1136,1137],{"class":509},");\n",[499,1139,1140],{"class":501,"line":821},[499,1141,526],{"emptyLinePlaceholder":381},[499,1143,1144],{"class":501,"line":857},[499,1145,1146],{"class":779},"    // Create users table\n",[499,1148,1149,1152,1154,1156,1158],{"class":501,"line":877},[499,1150,1151],{"class":505},"    await",[499,1153,788],{"class":509},[499,1155,791],{"class":538},[499,1157,794],{"class":516},[499,1159,520],{"class":509},[499,1161,1162,1164,1166,1168,1170],{"class":501,"line":882},[499,1163,1151],{"class":505},[499,1165,788],{"class":509},[499,1167,791],{"class":538},[499,1169,807],{"class":516},[499,1171,520],{"class":509},[499,1173,1174],{"class":501,"line":888},[499,1175,526],{"emptyLinePlaceholder":381},[499,1177,1178,1181],{"class":501,"line":922},[499,1179,1180],{"class":505},"    return",[499,1182,753],{"class":509},[499,1184,1185,1188,1191],{"class":501,"line":927},[499,1186,1187],{"class":509},"      result: ",[499,1189,1190],{"class":516},"\"Database migrations complete!\"",[499,1192,560],{"class":509},[499,1194,1195],{"class":501,"line":935},[499,1196,1197],{"class":509},"    };\n",[499,1199,1200],{"class":501,"line":941},[499,1201,576],{"class":509},[499,1203,1204],{"class":501,"line":947},[499,1205,605],{"class":509},[1207,1208,1209],"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.",[1211,1212,1214],"h2",{"id":1213},"querying-the-database","Querying the Database",[489,1216,1217],{"className":491,"code":695,"filename":487,"language":494,"meta":5,"style":5},[496,1218,1219,1231,1243,1247,1265,1277,1281,1285,1297,1309,1313,1317,1343,1359,1363,1367,1393,1397,1403,1407,1411],{"__ignoreMap":5},[499,1220,1221,1223,1225,1227,1229],{"class":501,"line":502},[499,1222,506],{"class":505},[499,1224,704],{"class":509},[499,1226,513],{"class":505},[499,1228,709],{"class":516},[499,1230,520],{"class":509},[499,1232,1233,1235,1237,1239,1241],{"class":501,"line":523},[499,1234,506],{"class":505},[499,1236,718],{"class":509},[499,1238,513],{"class":505},[499,1240,723],{"class":516},[499,1242,520],{"class":509},[499,1244,1245],{"class":501,"line":529},[499,1246,526],{"emptyLinePlaceholder":381},[499,1248,1249,1251,1253,1255,1257,1259,1261,1263],{"class":501,"line":545},[499,1250,532],{"class":505},[499,1252,535],{"class":505},[499,1254,738],{"class":538},[499,1256,741],{"class":509},[499,1258,744],{"class":505},[499,1260,747],{"class":509},[499,1262,750],{"class":505},[499,1264,753],{"class":509},[499,1266,1267,1269,1271,1273,1275],{"class":501,"line":551},[499,1268,758],{"class":505},[499,1270,761],{"class":557},[499,1272,764],{"class":505},[499,1274,767],{"class":538},[499,1276,770],{"class":509},[499,1278,1279],{"class":501,"line":563},[499,1280,526],{"emptyLinePlaceholder":381},[499,1282,1283],{"class":501,"line":573},[499,1284,780],{"class":779},[499,1286,1287,1289,1291,1293,1295],{"class":501,"line":579},[499,1288,785],{"class":505},[499,1290,788],{"class":509},[499,1292,791],{"class":538},[499,1294,794],{"class":516},[499,1296,520],{"class":509},[499,1298,1299,1301,1303,1305,1307],{"class":501,"line":585},[499,1300,785],{"class":505},[499,1302,788],{"class":509},[499,1304,791],{"class":538},[499,1306,807],{"class":516},[499,1308,520],{"class":509},[499,1310,1311],{"class":501,"line":597},[499,1312,526],{"emptyLinePlaceholder":381},[499,1314,1315],{"class":501,"line":602},[499,1316,818],{"class":779},[499,1318,1319,1321,1323,1325,1327,1329,1331,1333,1335,1337,1339,1341],{"class":501,"line":821},[499,1320,758],{"class":505},[499,1322,826],{"class":557},[499,1324,764],{"class":505},[499,1326,831],{"class":538},[499,1328,834],{"class":509},[499,1330,837],{"class":538},[499,1332,834],{"class":509},[499,1334,842],{"class":538},[499,1336,845],{"class":509},[499,1338,848],{"class":505},[499,1340,851],{"class":557},[499,1342,854],{"class":509},[499,1344,1345,1347,1349,1351,1353,1355,1357],{"class":501,"line":857},[499,1346,785],{"class":505},[499,1348,788],{"class":509},[499,1350,791],{"class":538},[499,1352,866],{"class":516},[499,1354,869],{"class":509},[499,1356,872],{"class":516},[499,1358,520],{"class":509},[499,1360,1361],{"class":501,"line":877},[499,1362,526],{"emptyLinePlaceholder":381},[499,1364,1365],{"class":501,"line":882},[499,1366,885],{"class":779},[499,1368,1369,1371,1373,1375,1377,1379,1381,1383,1385,1387,1389,1391],{"class":501,"line":888},[499,1370,758],{"class":505},[499,1372,893],{"class":509},[499,1374,896],{"class":557},[499,1376,899],{"class":509},[499,1378,902],{"class":505},[499,1380,905],{"class":505},[499,1382,788],{"class":509},[499,1384,791],{"class":538},[499,1386,912],{"class":516},[499,1388,869],{"class":509},[499,1390,917],{"class":516},[499,1392,520],{"class":509},[499,1394,1395],{"class":501,"line":922},[499,1396,526],{"emptyLinePlaceholder":381},[499,1398,1399,1401],{"class":501,"line":927},[499,1400,930],{"class":505},[499,1402,753],{"class":509},[499,1404,1405],{"class":501,"line":935},[499,1406,938],{"class":509},[499,1408,1409],{"class":501,"line":941},[499,1410,944],{"class":509},[499,1412,1413],{"class":501,"line":947},[499,1414,605],{"class":509},[1207,1416,1417,1418,1421,1422,1425,1426,1429],{},"Retrieve the database instance using ",[496,1419,1420],{},"useDatabase()",". The database can be queried using ",[496,1423,1424],{},"db.sql",", and variables like ",[496,1427,1428],{},"${userId}"," are automatically escaped to prevent SQL injection.",[1211,1431,1433],{"id":1432},"running-migrations-with-tasks","Running Migrations with Tasks",[1207,1435,1436,1437,1440],{},"Nitro tasks let you run operations outside of request handlers. For database migrations, create a task file in ",[496,1438,1439],{},"tasks/"," and run it via the CLI. This keeps schema changes separate from your application code.",[489,1442,1443],{"className":491,"code":1030,"filename":1031,"language":494,"meta":5,"style":5},[496,1444,1445,1457,1469,1473,1483,1487,1495,1499,1507,1519,1523,1535,1539,1543,1555,1567,1571,1577,1585,1589,1593],{"__ignoreMap":5},[499,1446,1447,1449,1451,1453,1455],{"class":501,"line":502},[499,1448,506],{"class":505},[499,1450,1040],{"class":509},[499,1452,513],{"class":505},[499,1454,1045],{"class":516},[499,1456,520],{"class":509},[499,1458,1459,1461,1463,1465,1467],{"class":501,"line":523},[499,1460,506],{"class":505},[499,1462,718],{"class":509},[499,1464,513],{"class":505},[499,1466,723],{"class":516},[499,1468,520],{"class":509},[499,1470,1471],{"class":501,"line":529},[499,1472,526],{"emptyLinePlaceholder":381},[499,1474,1475,1477,1479,1481],{"class":501,"line":545},[499,1476,532],{"class":505},[499,1478,535],{"class":505},[499,1480,1072],{"class":538},[499,1482,542],{"class":509},[499,1484,1485],{"class":501,"line":551},[499,1486,1079],{"class":509},[499,1488,1489,1491,1493],{"class":501,"line":563},[499,1490,1084],{"class":509},[499,1492,1087],{"class":516},[499,1494,560],{"class":509},[499,1496,1497],{"class":501,"line":573},[499,1498,576],{"class":509},[499,1500,1501,1503,1505],{"class":501,"line":579},[499,1502,1098],{"class":505},[499,1504,1101],{"class":538},[499,1506,1104],{"class":509},[499,1508,1509,1511,1513,1515,1517],{"class":501,"line":585},[499,1510,1109],{"class":505},[499,1512,761],{"class":557},[499,1514,764],{"class":505},[499,1516,767],{"class":538},[499,1518,770],{"class":509},[499,1520,1521],{"class":501,"line":597},[499,1522,526],{"emptyLinePlaceholder":381},[499,1524,1525,1527,1529,1531,1533],{"class":501,"line":602},[499,1526,1126],{"class":509},[499,1528,1129],{"class":538},[499,1530,741],{"class":509},[499,1532,1134],{"class":516},[499,1534,1137],{"class":509},[499,1536,1537],{"class":501,"line":821},[499,1538,526],{"emptyLinePlaceholder":381},[499,1540,1541],{"class":501,"line":857},[499,1542,1146],{"class":779},[499,1544,1545,1547,1549,1551,1553],{"class":501,"line":877},[499,1546,1151],{"class":505},[499,1548,788],{"class":509},[499,1550,791],{"class":538},[499,1552,794],{"class":516},[499,1554,520],{"class":509},[499,1556,1557,1559,1561,1563,1565],{"class":501,"line":882},[499,1558,1151],{"class":505},[499,1560,788],{"class":509},[499,1562,791],{"class":538},[499,1564,807],{"class":516},[499,1566,520],{"class":509},[499,1568,1569],{"class":501,"line":888},[499,1570,526],{"emptyLinePlaceholder":381},[499,1572,1573,1575],{"class":501,"line":922},[499,1574,1180],{"class":505},[499,1576,753],{"class":509},[499,1578,1579,1581,1583],{"class":501,"line":927},[499,1580,1187],{"class":509},[499,1582,1190],{"class":516},[499,1584,560],{"class":509},[499,1586,1587],{"class":501,"line":935},[499,1588,1197],{"class":509},[499,1590,1591],{"class":501,"line":941},[499,1592,576],{"class":509},[499,1594,1595],{"class":501,"line":947},[499,1596,605],{"class":509},[1211,1598,1600],{"id":1599},"learn-more","Learn More",[1602,1603,1604,1610],"ul",{},[1605,1606,1607],"li",{},[1608,1609,38],"a",{"href":39},[1605,1611,1612],{},[1608,1613,53],{"href":54},[1615,1616,1617],"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":1619},[1620,1621,1622],{"id":1213,"depth":523,"text":1214},{"id":1432,"depth":523,"text":1433},{"id":1599,"depth":523,"text":1600},"md",{"automd":381,"category":382,"icon":248},{"icon":248},{"title":38,"description":394},"3TQGrvMVG6himiOyovpsWxV68ZdwP136XL_jKok2rEY",[1629,1630],{"title":241,"path":242,"stem":243,"description":391,"icon":244,"children":-1},{"title":250,"path":251,"stem":252,"description":397,"icon":253,"children":-1},1773181197518]