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