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