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