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