bun-types 1.3.2-canary.20251106T140813 → 1.3.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bun.d.ts +102 -6
- package/docs/bundler/bytecode.mdx +465 -0
- package/docs/bundler/css.mdx +1024 -0
- package/docs/bundler/esbuild.mdx +253 -0
- package/docs/bundler/executables.mdx +535 -0
- package/docs/bundler/fullstack.mdx +1064 -0
- package/docs/bundler/hot-reloading.mdx +229 -0
- package/docs/bundler/html-static.mdx +386 -0
- package/docs/bundler/index.mdx +1499 -0
- package/docs/bundler/loaders.mdx +356 -0
- package/docs/bundler/macros.mdx +328 -0
- package/docs/bundler/minifier.mdx +1306 -0
- package/docs/bundler/plugins.mdx +411 -0
- package/docs/feedback.mdx +85 -0
- package/docs/guides/binary/arraybuffer-to-array.mdx +29 -0
- package/docs/guides/binary/arraybuffer-to-blob.mdx +26 -0
- package/docs/guides/binary/arraybuffer-to-buffer.mdx +27 -0
- package/docs/guides/binary/arraybuffer-to-string.mdx +17 -0
- package/docs/guides/binary/arraybuffer-to-typedarray.mdx +41 -0
- package/docs/guides/binary/blob-to-arraybuffer.mdx +16 -0
- package/docs/guides/binary/blob-to-dataview.mdx +16 -0
- package/docs/guides/binary/blob-to-stream.mdx +16 -0
- package/docs/guides/binary/blob-to-string.mdx +17 -0
- package/docs/guides/binary/blob-to-typedarray.mdx +16 -0
- package/docs/guides/binary/buffer-to-arraybuffer.mdx +16 -0
- package/docs/guides/binary/buffer-to-blob.mdx +16 -0
- package/docs/guides/binary/buffer-to-readablestream.mdx +43 -0
- package/docs/guides/binary/buffer-to-string.mdx +27 -0
- package/docs/guides/binary/buffer-to-typedarray.mdx +16 -0
- package/docs/guides/binary/dataview-to-string.mdx +17 -0
- package/docs/guides/binary/typedarray-to-arraybuffer.mdx +27 -0
- package/docs/guides/binary/typedarray-to-blob.mdx +18 -0
- package/docs/guides/binary/typedarray-to-buffer.mdx +16 -0
- package/docs/guides/binary/typedarray-to-dataview.mdx +16 -0
- package/docs/guides/binary/typedarray-to-readablestream.mdx +43 -0
- package/docs/guides/binary/typedarray-to-string.mdx +18 -0
- package/docs/guides/deployment/aws-lambda.mdx +204 -0
- package/docs/guides/deployment/digital-ocean.mdx +161 -0
- package/docs/guides/deployment/google-cloud-run.mdx +197 -0
- package/docs/guides/deployment/railway.mdx +145 -0
- package/docs/guides/deployment/render.mdx +82 -0
- package/docs/guides/deployment/vercel.mdx +99 -0
- package/docs/guides/ecosystem/astro.mdx +82 -0
- package/docs/guides/ecosystem/discordjs.mdx +80 -0
- package/docs/guides/ecosystem/docker.mdx +151 -0
- package/docs/guides/ecosystem/drizzle.mdx +195 -0
- package/docs/guides/ecosystem/edgedb.mdx +257 -0
- package/docs/guides/ecosystem/elysia.mdx +31 -0
- package/docs/guides/ecosystem/express.mdx +43 -0
- package/docs/guides/ecosystem/hono.mdx +47 -0
- package/docs/guides/ecosystem/mongoose.mdx +92 -0
- package/docs/guides/ecosystem/neon-drizzle.mdx +234 -0
- package/docs/guides/ecosystem/neon-serverless-postgres.mdx +60 -0
- package/docs/guides/ecosystem/nextjs.mdx +57 -0
- package/docs/guides/ecosystem/nuxt.mdx +90 -0
- package/docs/guides/ecosystem/pm2.mdx +55 -0
- package/docs/guides/ecosystem/prisma-postgres.mdx +169 -0
- package/docs/guides/ecosystem/prisma.mdx +164 -0
- package/docs/guides/ecosystem/qwik.mdx +114 -0
- package/docs/guides/ecosystem/react.mdx +52 -0
- package/docs/guides/ecosystem/remix.mdx +97 -0
- package/docs/guides/ecosystem/sentry.mdx +54 -0
- package/docs/guides/ecosystem/solidstart.mdx +66 -0
- package/docs/guides/ecosystem/ssr-react.mdx +49 -0
- package/docs/guides/ecosystem/stric.mdx +54 -0
- package/docs/guides/ecosystem/sveltekit.mdx +138 -0
- package/docs/guides/ecosystem/systemd.mdx +114 -0
- package/docs/guides/ecosystem/upstash.mdx +87 -0
- package/docs/guides/ecosystem/vite.mdx +77 -0
- package/docs/guides/html-rewriter/extract-links.mdx +72 -0
- package/docs/guides/html-rewriter/extract-social-meta.mdx +97 -0
- package/docs/guides/http/cluster.mdx +69 -0
- package/docs/guides/http/fetch-unix.mdx +35 -0
- package/docs/guides/http/fetch.mdx +26 -0
- package/docs/guides/http/file-uploads.mdx +97 -0
- package/docs/guides/http/hot.mdx +28 -0
- package/docs/guides/http/proxy.mdx +26 -0
- package/docs/guides/http/server.mdx +48 -0
- package/docs/guides/http/simple.mdx +20 -0
- package/docs/guides/http/stream-file.mdx +50 -0
- package/docs/guides/http/stream-iterator.mdx +49 -0
- package/docs/guides/http/stream-node-streams-in-bun.mdx +22 -0
- package/docs/guides/http/tls.mdx +32 -0
- package/docs/guides/index.mdx +10 -0
- package/docs/guides/install/add-dev.mdx +28 -0
- package/docs/guides/install/add-git.mdx +38 -0
- package/docs/guides/install/add-optional.mdx +27 -0
- package/docs/guides/install/add-peer.mdx +45 -0
- package/docs/guides/install/add-tarball.mdx +35 -0
- package/docs/guides/install/add.mdx +44 -0
- package/docs/guides/install/azure-artifacts.mdx +76 -0
- package/docs/guides/install/cicd.mdx +43 -0
- package/docs/guides/install/custom-registry.mdx +32 -0
- package/docs/guides/install/from-npm-install-to-bun-install.mdx +230 -0
- package/docs/guides/install/git-diff-bun-lockfile.mdx +47 -0
- package/docs/guides/install/jfrog-artifactory.mdx +28 -0
- package/docs/guides/install/npm-alias.mdx +25 -0
- package/docs/guides/install/registry-scope.mdx +40 -0
- package/docs/guides/install/trusted.mdx +50 -0
- package/docs/guides/install/workspaces.mdx +70 -0
- package/docs/guides/install/yarnlock.mdx +50 -0
- package/docs/guides/process/argv.mdx +66 -0
- package/docs/guides/process/ctrl-c.mdx +18 -0
- package/docs/guides/process/ipc.mdx +69 -0
- package/docs/guides/process/nanoseconds.mdx +15 -0
- package/docs/guides/process/os-signals.mdx +41 -0
- package/docs/guides/process/spawn-stderr.mdx +34 -0
- package/docs/guides/process/spawn-stdout.mdx +28 -0
- package/docs/guides/process/spawn.mdx +43 -0
- package/docs/guides/process/stdin.mdx +62 -0
- package/docs/guides/read-file/arraybuffer.mdx +30 -0
- package/docs/guides/read-file/buffer.mdx +21 -0
- package/docs/guides/read-file/exists.mdx +18 -0
- package/docs/guides/read-file/json.mdx +19 -0
- package/docs/guides/read-file/mime.mdx +22 -0
- package/docs/guides/read-file/stream.mdx +28 -0
- package/docs/guides/read-file/string.mdx +24 -0
- package/docs/guides/read-file/uint8array.mdx +23 -0
- package/docs/guides/read-file/watch.mdx +66 -0
- package/docs/guides/runtime/build-time-constants.mdx +295 -0
- package/docs/guides/runtime/cicd.mdx +45 -0
- package/docs/guides/runtime/codesign-macos-executable.mdx +61 -0
- package/docs/guides/runtime/define-constant.mdx +149 -0
- package/docs/guides/runtime/delete-directory.mdx +39 -0
- package/docs/guides/runtime/delete-file.mdx +21 -0
- package/docs/guides/runtime/heap-snapshot.mdx +28 -0
- package/docs/guides/runtime/import-html.mdx +17 -0
- package/docs/guides/runtime/import-json.mdx +46 -0
- package/docs/guides/runtime/import-toml.mdx +32 -0
- package/docs/guides/runtime/import-yaml.mdx +104 -0
- package/docs/guides/runtime/read-env.mdx +37 -0
- package/docs/guides/runtime/set-env.mdx +51 -0
- package/docs/guides/runtime/shell.mdx +42 -0
- package/docs/guides/runtime/timezone.mdx +38 -0
- package/docs/guides/runtime/tsconfig-paths.mdx +31 -0
- package/docs/guides/runtime/typescript.mdx +51 -0
- package/docs/guides/runtime/vscode-debugger.mdx +48 -0
- package/docs/guides/runtime/web-debugger.mdx +103 -0
- package/docs/guides/streams/node-readable-to-arraybuffer.mdx +13 -0
- package/docs/guides/streams/node-readable-to-blob.mdx +13 -0
- package/docs/guides/streams/node-readable-to-json.mdx +14 -0
- package/docs/guides/streams/node-readable-to-string.mdx +14 -0
- package/docs/guides/streams/node-readable-to-uint8array.mdx +13 -0
- package/docs/guides/streams/to-array.mdx +16 -0
- package/docs/guides/streams/to-arraybuffer.mdx +16 -0
- package/docs/guides/streams/to-blob.mdx +16 -0
- package/docs/guides/streams/to-buffer.mdx +17 -0
- package/docs/guides/streams/to-json.mdx +16 -0
- package/docs/guides/streams/to-string.mdx +16 -0
- package/docs/guides/streams/to-typedarray.mdx +24 -0
- package/docs/guides/test/bail.mdx +24 -0
- package/docs/guides/test/coverage-threshold.mdx +67 -0
- package/docs/guides/test/coverage.mdx +49 -0
- package/docs/guides/test/happy-dom.mdx +73 -0
- package/docs/guides/test/migrate-from-jest.mdx +125 -0
- package/docs/guides/test/mock-clock.mdx +50 -0
- package/docs/guides/test/mock-functions.mdx +70 -0
- package/docs/guides/test/rerun-each.mdx +16 -0
- package/docs/guides/test/run-tests.mdx +116 -0
- package/docs/guides/test/skip-tests.mdx +43 -0
- package/docs/guides/test/snapshot.mdx +102 -0
- package/docs/guides/test/spy-on.mdx +49 -0
- package/docs/guides/test/svelte-test.mdx +113 -0
- package/docs/guides/test/testing-library.mdx +93 -0
- package/docs/guides/test/timeout.mdx +17 -0
- package/docs/guides/test/todo-tests.mdx +74 -0
- package/docs/guides/test/update-snapshots.mdx +49 -0
- package/docs/guides/test/watch-mode.mdx +24 -0
- package/docs/guides/util/base64.mdx +17 -0
- package/docs/guides/util/deep-equals.mdx +41 -0
- package/docs/guides/util/deflate.mdx +20 -0
- package/docs/guides/util/detect-bun.mdx +25 -0
- package/docs/guides/util/entrypoint.mdx +19 -0
- package/docs/guides/util/escape-html.mdx +24 -0
- package/docs/guides/util/file-url-to-path.mdx +16 -0
- package/docs/guides/util/gzip.mdx +20 -0
- package/docs/guides/util/hash-a-password.mdx +56 -0
- package/docs/guides/util/import-meta-dir.mdx +15 -0
- package/docs/guides/util/import-meta-file.mdx +15 -0
- package/docs/guides/util/import-meta-path.mdx +15 -0
- package/docs/guides/util/javascript-uuid.mdx +25 -0
- package/docs/guides/util/main.mdx +43 -0
- package/docs/guides/util/path-to-file-url.mdx +16 -0
- package/docs/guides/util/sleep.mdx +24 -0
- package/docs/guides/util/version.mdx +23 -0
- package/docs/guides/util/which-path-to-executable-bin.mdx +17 -0
- package/docs/guides/websocket/compression.mdx +33 -0
- package/docs/guides/websocket/context.mdx +74 -0
- package/docs/guides/websocket/pubsub.mdx +40 -0
- package/docs/guides/websocket/simple.mdx +35 -0
- package/docs/guides/write-file/append.mdx +54 -0
- package/docs/guides/write-file/basic.mdx +46 -0
- package/docs/guides/write-file/blob.mdx +30 -0
- package/docs/guides/write-file/cat.mdx +19 -0
- package/docs/guides/write-file/file-cp.mdx +18 -0
- package/docs/guides/write-file/filesink.mdx +54 -0
- package/docs/guides/write-file/response.mdx +19 -0
- package/docs/guides/write-file/stdout.mdx +23 -0
- package/docs/guides/write-file/stream.mdx +19 -0
- package/docs/guides/write-file/unlink.mdx +18 -0
- package/docs/index.mdx +133 -0
- package/docs/installation.mdx +365 -0
- package/docs/pm/bunx.mdx +83 -0
- package/docs/pm/catalogs.mdx +292 -0
- package/docs/pm/cli/add.mdx +179 -0
- package/docs/pm/cli/audit.mdx +60 -0
- package/docs/pm/cli/install.mdx +471 -0
- package/docs/pm/cli/link.mdx +48 -0
- package/docs/pm/cli/outdated.mdx +197 -0
- package/docs/pm/cli/patch.mdx +69 -0
- package/docs/pm/cli/pm.mdx +319 -0
- package/docs/pm/cli/publish.mdx +123 -0
- package/docs/pm/cli/remove.mdx +16 -0
- package/docs/pm/cli/update.mdx +140 -0
- package/docs/pm/cli/why.mdx +84 -0
- package/docs/pm/filter.mdx +102 -0
- package/docs/pm/global-cache.mdx +72 -0
- package/docs/pm/isolated-installs.mdx +205 -0
- package/docs/pm/lifecycle.mdx +57 -0
- package/docs/pm/lockfile.mdx +64 -0
- package/docs/pm/npmrc.mdx +111 -0
- package/docs/pm/overrides.mdx +83 -0
- package/docs/pm/scopes-registries.mdx +35 -0
- package/docs/pm/security-scanner-api.mdx +95 -0
- package/docs/pm/workspaces.mdx +109 -0
- package/docs/project/benchmarking.mdx +218 -0
- package/docs/project/bindgen.mdx +223 -0
- package/docs/project/building-windows.mdx +133 -0
- package/docs/project/contributing.mdx +343 -0
- package/docs/project/feedback.mdx +20 -0
- package/docs/project/license.mdx +78 -0
- package/docs/project/roadmap.mdx +8 -0
- package/docs/quickstart.mdx +240 -0
- package/docs/runtime/auto-install.mdx +97 -0
- package/docs/runtime/binary-data.mdx +846 -0
- package/docs/runtime/bun-apis.mdx +59 -0
- package/docs/runtime/bunfig.mdx +642 -0
- package/docs/runtime/c-compiler.mdx +204 -0
- package/docs/runtime/child-process.mdx +532 -0
- package/docs/runtime/color.mdx +267 -0
- package/docs/runtime/console.mdx +67 -0
- package/docs/runtime/cookies.mdx +454 -0
- package/docs/runtime/debugger.mdx +335 -0
- package/docs/runtime/environment-variables.mdx +214 -0
- package/docs/runtime/ffi.mdx +565 -0
- package/docs/runtime/file-io.mdx +306 -0
- package/docs/runtime/file-system-router.mdx +118 -0
- package/docs/runtime/file-types.mdx +354 -0
- package/docs/runtime/glob.mdx +181 -0
- package/docs/runtime/globals.mdx +72 -0
- package/docs/runtime/hashing.mdx +315 -0
- package/docs/runtime/html-rewriter.mdx +340 -0
- package/docs/runtime/http/cookies.mdx +79 -0
- package/docs/runtime/http/error-handling.mdx +40 -0
- package/docs/runtime/http/metrics.mdx +36 -0
- package/docs/runtime/http/routing.mdx +289 -0
- package/docs/runtime/http/server.mdx +647 -0
- package/docs/runtime/http/tls.mdx +101 -0
- package/docs/runtime/http/websockets.mdx +404 -0
- package/docs/runtime/index.mdx +223 -0
- package/docs/runtime/jsx.mdx +115 -0
- package/docs/runtime/module-resolution.mdx +342 -0
- package/docs/runtime/networking/dns.mdx +111 -0
- package/docs/runtime/networking/fetch.mdx +468 -0
- package/docs/runtime/networking/tcp.mdx +239 -0
- package/docs/runtime/networking/udp.mdx +129 -0
- package/docs/runtime/node-api.mdx +19 -0
- package/docs/runtime/nodejs-compat.mdx +468 -0
- package/docs/runtime/plugins.mdx +405 -0
- package/docs/runtime/redis.mdx +582 -0
- package/docs/runtime/s3.mdx +863 -0
- package/docs/runtime/secrets.mdx +336 -0
- package/docs/runtime/semver.mdx +57 -0
- package/docs/runtime/shell.mdx +637 -0
- package/docs/runtime/sql.mdx +1404 -0
- package/docs/runtime/sqlite.mdx +699 -0
- package/docs/runtime/streams.mdx +232 -0
- package/docs/runtime/templating/create.mdx +269 -0
- package/docs/runtime/templating/init.mdx +58 -0
- package/docs/runtime/transpiler.mdx +288 -0
- package/docs/runtime/typescript.mdx +58 -0
- package/docs/runtime/utils.mdx +922 -0
- package/docs/runtime/watch-mode.mdx +161 -0
- package/docs/runtime/web-apis.mdx +29 -0
- package/docs/runtime/workers.mdx +328 -0
- package/docs/runtime/yaml.mdx +469 -0
- package/docs/snippets/cli/add.mdx +166 -0
- package/docs/snippets/cli/build.mdx +196 -0
- package/docs/snippets/cli/feedback.mdx +17 -0
- package/docs/snippets/cli/init.mdx +84 -0
- package/docs/snippets/cli/install.mdx +173 -0
- package/docs/snippets/cli/link.mdx +163 -0
- package/docs/snippets/cli/outdated.mdx +140 -0
- package/docs/snippets/cli/patch.mdx +171 -0
- package/docs/snippets/cli/publish.mdx +198 -0
- package/docs/snippets/cli/remove.mdx +146 -0
- package/docs/snippets/cli/run.mdx +293 -0
- package/docs/snippets/cli/test.mdx +100 -0
- package/docs/snippets/cli/update.mdx +144 -0
- package/docs/snippets/product-card.mdx +32 -0
- package/docs/snippets/product-tiles.mdx +94 -0
- package/docs/test/code-coverage.mdx +409 -0
- package/docs/test/configuration.mdx +467 -0
- package/docs/test/dates-times.mdx +129 -0
- package/docs/test/discovery.mdx +90 -0
- package/docs/test/dom.mdx +226 -0
- package/docs/test/index.mdx +380 -0
- package/docs/test/lifecycle.mdx +348 -0
- package/docs/test/mocks.mdx +637 -0
- package/docs/test/reporters.mdx +117 -0
- package/docs/test/runtime-behavior.mdx +342 -0
- package/docs/test/snapshots.mdx +434 -0
- package/docs/test/writing-tests.mdx +635 -0
- package/docs/typescript.mdx +54 -0
- package/package.json +8 -6
- package/test.d.ts +2 -2
|
@@ -0,0 +1,257 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Use EdgeDB with Bun
|
|
3
|
+
sidebarTitle: EdgeDB with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
EdgeDB is a graph-relational database powered by Postgres under the hood. It provides a declarative schema language, migrations system, and object-oriented query language, in addition to supporting raw SQL queries. It solves the object-relational mapping problem at the database layer, eliminating the need for an ORM library in your application code.
|
|
8
|
+
|
|
9
|
+
---
|
|
10
|
+
|
|
11
|
+
First, [install EdgeDB](https://www.edgedb.com/install) if you haven't already.
|
|
12
|
+
|
|
13
|
+
<CodeGroup>
|
|
14
|
+
|
|
15
|
+
```sh Linux/macOS terminal icon="terminal"
|
|
16
|
+
curl --proto '=https' --tlsv1.2 -sSf https://sh.edgedb.com | sh
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
```sh Windows terminal icon="windows"
|
|
20
|
+
iwr https://ps1.edgedb.com -useb | iex
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
</CodeGroup>
|
|
24
|
+
|
|
25
|
+
---
|
|
26
|
+
|
|
27
|
+
Use `bun init` to create a fresh project.
|
|
28
|
+
|
|
29
|
+
```sh terminal icon="terminal"
|
|
30
|
+
mkdir my-edgedb-app
|
|
31
|
+
cd my-edgedb-app
|
|
32
|
+
bun init -y
|
|
33
|
+
```
|
|
34
|
+
|
|
35
|
+
---
|
|
36
|
+
|
|
37
|
+
We'll use the EdgeDB CLI to initialize an EdgeDB instance for our project. This creates an `edgedb.toml` file in our project root.
|
|
38
|
+
|
|
39
|
+
```sh terminal icon="terminal"
|
|
40
|
+
edgedb project init
|
|
41
|
+
```
|
|
42
|
+
|
|
43
|
+
```txt
|
|
44
|
+
No `edgedb.toml` found in `/Users/colinmcd94/Documents/bun/fun/examples/my-edgedb-app` or above
|
|
45
|
+
Do you want to initialize a new project? [Y/n]
|
|
46
|
+
> Y
|
|
47
|
+
Specify the name of EdgeDB instance to use with this project [default: my_edgedb_app]:
|
|
48
|
+
> my_edgedb_app
|
|
49
|
+
Checking EdgeDB versions...
|
|
50
|
+
Specify the version of EdgeDB to use with this project [default: x.y]:
|
|
51
|
+
> x.y
|
|
52
|
+
┌─────────────────────┬────────────────────────────────────────────────────────────────────────┐
|
|
53
|
+
│ Project directory │ /Users/colinmcd94/Documents/bun/fun/examples/my-edgedb-app │
|
|
54
|
+
│ Project config │ /Users/colinmcd94/Documents/bun/fun/examples/my-edgedb-app/edgedb.toml │
|
|
55
|
+
│ Schema dir (empty) │ /Users/colinmcd94/Documents/bun/fun/examples/my-edgedb-app/dbschema │
|
|
56
|
+
│ Installation method │ portable package │
|
|
57
|
+
│ Version │ x.y+6d5921b │
|
|
58
|
+
│ Instance name │ my_edgedb_app │
|
|
59
|
+
└─────────────────────┴────────────────────────────────────────────────────────────────────────┘
|
|
60
|
+
Version x.y+6d5921b is already downloaded
|
|
61
|
+
Initializing EdgeDB instance...
|
|
62
|
+
Applying migrations...
|
|
63
|
+
Everything is up to date. Revision initial
|
|
64
|
+
Project initialized.
|
|
65
|
+
To connect to my_edgedb_app, run `edgedb`
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
---
|
|
69
|
+
|
|
70
|
+
To see if the database is running, let's open a REPL and run a simple query.
|
|
71
|
+
|
|
72
|
+
```sh terminal icon="terminal"
|
|
73
|
+
edgedb
|
|
74
|
+
edgedb> select 1 + 1;
|
|
75
|
+
```
|
|
76
|
+
|
|
77
|
+
```txt
|
|
78
|
+
2
|
|
79
|
+
```
|
|
80
|
+
|
|
81
|
+
Then run `\quit` to exit the REPL.
|
|
82
|
+
|
|
83
|
+
```sh terminal icon="terminal"
|
|
84
|
+
edgedb> \quit
|
|
85
|
+
```
|
|
86
|
+
|
|
87
|
+
---
|
|
88
|
+
|
|
89
|
+
With the project initialized, we can define a schema. The `edgedb project init` command already created a `dbschema/default.esdl` file to contain our schema.
|
|
90
|
+
|
|
91
|
+
```txt File Tree icon="folder-tree"
|
|
92
|
+
dbschema
|
|
93
|
+
├── default.esdl
|
|
94
|
+
└── migrations
|
|
95
|
+
```
|
|
96
|
+
|
|
97
|
+
---
|
|
98
|
+
|
|
99
|
+
Open that file and paste the following contents.
|
|
100
|
+
|
|
101
|
+
```ts default.esdl icon="file-code"
|
|
102
|
+
module default {
|
|
103
|
+
type Movie {
|
|
104
|
+
required title: str;
|
|
105
|
+
releaseYear: int64;
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
```
|
|
109
|
+
|
|
110
|
+
---
|
|
111
|
+
|
|
112
|
+
Then generate and apply an initial migration.
|
|
113
|
+
|
|
114
|
+
```sh terminal icon="terminal"
|
|
115
|
+
edgedb migration create
|
|
116
|
+
```
|
|
117
|
+
|
|
118
|
+
```txt
|
|
119
|
+
Created /Users/colinmcd94/Documents/bun/fun/examples/my-edgedb-app/dbschema/migrations/00001.edgeql, id: m1uwekrn4ni4qs7ul7hfar4xemm5kkxlpswolcoyqj3xdhweomwjrq
|
|
120
|
+
```
|
|
121
|
+
|
|
122
|
+
```sh terminal icon="terminal"
|
|
123
|
+
edgedb migrate
|
|
124
|
+
```
|
|
125
|
+
|
|
126
|
+
```txt
|
|
127
|
+
Applied m1uwekrn4ni4qs7ul7hfar4xemm5kkxlpswolcoyqj3xdhweomwjrq (00001.edgeql)
|
|
128
|
+
```
|
|
129
|
+
|
|
130
|
+
---
|
|
131
|
+
|
|
132
|
+
With our schema applied, let's execute some queries using EdgeDB's JavaScript client library. We'll install the client library and EdgeDB's codegen CLI, and create a `seed.ts`.file.
|
|
133
|
+
|
|
134
|
+
```sh terminal icon="terminal"
|
|
135
|
+
bun add edgedb
|
|
136
|
+
bun add -D @edgedb/generate
|
|
137
|
+
touch seed.ts
|
|
138
|
+
```
|
|
139
|
+
|
|
140
|
+
---
|
|
141
|
+
|
|
142
|
+
Paste the following code into `seed.ts`.
|
|
143
|
+
|
|
144
|
+
The client auto-connects to the database. We insert a couple movies using the `.execute()` method. We will use EdgeQL's `for` expression to turn this bulk insert into a single optimized query.
|
|
145
|
+
|
|
146
|
+
```ts seed.ts icon="/icons/typescript.svg"
|
|
147
|
+
import { createClient } from "edgedb";
|
|
148
|
+
|
|
149
|
+
const client = createClient();
|
|
150
|
+
|
|
151
|
+
const INSERT_MOVIE = `
|
|
152
|
+
with movies := <array<tuple<title: str, year: int64>>>$movies
|
|
153
|
+
for movie in array_unpack(movies) union (
|
|
154
|
+
insert Movie {
|
|
155
|
+
title := movie.title,
|
|
156
|
+
releaseYear := movie.year,
|
|
157
|
+
}
|
|
158
|
+
)
|
|
159
|
+
`;
|
|
160
|
+
|
|
161
|
+
const movies = [
|
|
162
|
+
{ title: "The Matrix", year: 1999 },
|
|
163
|
+
{ title: "The Matrix Reloaded", year: 2003 },
|
|
164
|
+
{ title: "The Matrix Revolutions", year: 2003 },
|
|
165
|
+
];
|
|
166
|
+
|
|
167
|
+
await client.execute(INSERT_MOVIE, { movies });
|
|
168
|
+
|
|
169
|
+
console.log(`Seeding complete.`);
|
|
170
|
+
process.exit();
|
|
171
|
+
```
|
|
172
|
+
|
|
173
|
+
---
|
|
174
|
+
|
|
175
|
+
Then run this file with Bun.
|
|
176
|
+
|
|
177
|
+
```sh terminal icon="terminal"
|
|
178
|
+
bun run seed.ts
|
|
179
|
+
```
|
|
180
|
+
|
|
181
|
+
```txt
|
|
182
|
+
Seeding complete.
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
---
|
|
186
|
+
|
|
187
|
+
EdgeDB implements a number of code generation tools for TypeScript. To query our newly seeded database in a typesafe way, we'll use `@edgedb/generate` to code-generate the EdgeQL query builder.
|
|
188
|
+
|
|
189
|
+
```sh terminal icon="terminal"
|
|
190
|
+
bunx @edgedb/generate edgeql-js
|
|
191
|
+
```
|
|
192
|
+
|
|
193
|
+
```txt
|
|
194
|
+
Generating query builder...
|
|
195
|
+
Detected tsconfig.json, generating TypeScript files.
|
|
196
|
+
To override this, use the --target flag.
|
|
197
|
+
Run `npx @edgedb/generate --help` for full options.
|
|
198
|
+
Introspecting database schema...
|
|
199
|
+
Writing files to ./dbschema/edgeql-js
|
|
200
|
+
Generation complete! 🤘
|
|
201
|
+
Checking the generated query builder into version control
|
|
202
|
+
is not recommended. Would you like to update .gitignore to ignore
|
|
203
|
+
the query builder directory? The following line will be added:
|
|
204
|
+
|
|
205
|
+
dbschema/edgeql-js
|
|
206
|
+
|
|
207
|
+
[y/n] (leave blank for "y")
|
|
208
|
+
> y
|
|
209
|
+
```
|
|
210
|
+
|
|
211
|
+
---
|
|
212
|
+
|
|
213
|
+
In `index.ts`, we can import the generated query builder from `./dbschema/edgeql-js` and write a simple select query.
|
|
214
|
+
|
|
215
|
+
```ts index.ts icon="/icons/typescript.svg"
|
|
216
|
+
import { createClient } from "edgedb";
|
|
217
|
+
import e from "./dbschema/edgeql-js";
|
|
218
|
+
|
|
219
|
+
const client = createClient();
|
|
220
|
+
|
|
221
|
+
const query = e.select(e.Movie, () => ({
|
|
222
|
+
title: true,
|
|
223
|
+
releaseYear: true,
|
|
224
|
+
}));
|
|
225
|
+
|
|
226
|
+
const results = await query.run(client);
|
|
227
|
+
console.log(results);
|
|
228
|
+
|
|
229
|
+
results; // { title: string, releaseYear: number | null }[]
|
|
230
|
+
```
|
|
231
|
+
|
|
232
|
+
---
|
|
233
|
+
|
|
234
|
+
Running the file with Bun, we can see the list of movies we inserted.
|
|
235
|
+
|
|
236
|
+
```sh terminal icon="terminal"
|
|
237
|
+
bun run index.ts
|
|
238
|
+
```
|
|
239
|
+
|
|
240
|
+
```txt
|
|
241
|
+
[
|
|
242
|
+
{
|
|
243
|
+
title: "The Matrix",
|
|
244
|
+
releaseYear: 1999
|
|
245
|
+
}, {
|
|
246
|
+
title: "The Matrix Reloaded",
|
|
247
|
+
releaseYear: 2003
|
|
248
|
+
}, {
|
|
249
|
+
title: "The Matrix Revolutions",
|
|
250
|
+
releaseYear: 2003
|
|
251
|
+
}
|
|
252
|
+
]
|
|
253
|
+
```
|
|
254
|
+
|
|
255
|
+
---
|
|
256
|
+
|
|
257
|
+
For complete documentation, refer to the [EdgeDB docs](https://www.edgedb.com/docs).
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Build an HTTP server using Elysia and Bun
|
|
3
|
+
sidebarTitle: Elysia with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
[Elysia](https://elysiajs.com) is a Bun-first performance focused web framework that takes full advantage of Bun's HTTP, file system, and hot reloading APIs. Get started with `bun create`.
|
|
8
|
+
|
|
9
|
+
```bash terminal icon="terminal"
|
|
10
|
+
bun create elysia myapp
|
|
11
|
+
cd myapp
|
|
12
|
+
bun run dev
|
|
13
|
+
```
|
|
14
|
+
|
|
15
|
+
---
|
|
16
|
+
|
|
17
|
+
To define a simple HTTP route and start a server with Elysia:
|
|
18
|
+
|
|
19
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
20
|
+
import { Elysia } from "elysia";
|
|
21
|
+
|
|
22
|
+
const app = new Elysia().get("/", () => "Hello Elysia").listen(8080);
|
|
23
|
+
|
|
24
|
+
console.log(`🦊 Elysia is running at on port ${app.server?.port}...`);
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
29
|
+
Elysia is a full-featured server framework with Express-like syntax, type inference, middleware, file uploads, and plugins for JWT authentication, tRPC, and more. It's also is one of the [fastest Bun web frameworks](https://github.com/SaltyAom/bun-http-framework-benchmark).
|
|
30
|
+
|
|
31
|
+
Refer to the Elysia [documentation](https://elysiajs.com/quick-start.html) for more information.
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Build an HTTP server using Express and Bun
|
|
3
|
+
sidebarTitle: Express with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
Express and other major Node.js HTTP libraries should work out of the box. Bun implements the [`node:http`](https://nodejs.org/api/http.html) and [`node:https`](https://nodejs.org/api/https.html) modules that these libraries rely on.
|
|
8
|
+
|
|
9
|
+
<Note>
|
|
10
|
+
Refer to the [Runtime > Node.js APIs](https://bun.com/docs/runtime/nodejs-apis#node-http) page for more detailed
|
|
11
|
+
compatibility information.
|
|
12
|
+
</Note>
|
|
13
|
+
|
|
14
|
+
```sh terminal icon="terminal"
|
|
15
|
+
bun add express
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
---
|
|
19
|
+
|
|
20
|
+
To define a simple HTTP route and start a server with Express:
|
|
21
|
+
|
|
22
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
23
|
+
import express from "express";
|
|
24
|
+
|
|
25
|
+
const app = express();
|
|
26
|
+
const port = 8080;
|
|
27
|
+
|
|
28
|
+
app.get("/", (req, res) => {
|
|
29
|
+
res.send("Hello World!");
|
|
30
|
+
});
|
|
31
|
+
|
|
32
|
+
app.listen(port, () => {
|
|
33
|
+
console.log(`Listening on port ${port}...`);
|
|
34
|
+
});
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
To start the server on `localhost`:
|
|
40
|
+
|
|
41
|
+
```sh terminal icon="terminal"
|
|
42
|
+
bun server.ts
|
|
43
|
+
```
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Build an HTTP server using Hono and Bun
|
|
3
|
+
sidebarTitle: Hono with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
[Hono](https://github.com/honojs/hono) is a lightweight ultrafast web framework designed for the edge.
|
|
8
|
+
|
|
9
|
+
```ts server.ts icon="/icons/typescript.svg"
|
|
10
|
+
import { Hono } from "hono";
|
|
11
|
+
const app = new Hono();
|
|
12
|
+
|
|
13
|
+
app.get("/", c => c.text("Hono!"));
|
|
14
|
+
|
|
15
|
+
export default app;
|
|
16
|
+
```
|
|
17
|
+
|
|
18
|
+
---
|
|
19
|
+
|
|
20
|
+
Use `create-hono` to get started with one of Hono's project templates. Select `bun` when prompted for a template.
|
|
21
|
+
|
|
22
|
+
```sh terminal icon="terminal"
|
|
23
|
+
bun create hono myapp
|
|
24
|
+
```
|
|
25
|
+
|
|
26
|
+
```txt
|
|
27
|
+
✔ Which template do you want to use? › bun
|
|
28
|
+
cloned honojs/starter#main to /path/to/myapp
|
|
29
|
+
✔ Copied project files
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
```sh terminal icon="terminal"
|
|
33
|
+
cd myapp
|
|
34
|
+
bun install
|
|
35
|
+
```
|
|
36
|
+
|
|
37
|
+
---
|
|
38
|
+
|
|
39
|
+
Then start the dev server and visit [localhost:3000](http://localhost:3000).
|
|
40
|
+
|
|
41
|
+
```sh terminal icon="terminal"
|
|
42
|
+
bun run dev
|
|
43
|
+
```
|
|
44
|
+
|
|
45
|
+
---
|
|
46
|
+
|
|
47
|
+
Refer to Hono's guide on [getting started with Bun](https://hono.dev/getting-started/bun) for more information.
|
|
@@ -0,0 +1,92 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Read and write data to MongoDB using Mongoose and Bun
|
|
3
|
+
sidebarTitle: Mongoose with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
MongoDB and Mongoose work out of the box with Bun. This guide assumes you've already installed MongoDB and are running it as background process/service on your development machine. Follow [this guide](https://www.mongodb.com/docs/manual/installation/) for details.
|
|
8
|
+
|
|
9
|
+
---
|
|
10
|
+
|
|
11
|
+
Once MongoDB is running, create a directory and initialize it with `bun init`.
|
|
12
|
+
|
|
13
|
+
```sh terminal icon="terminal"
|
|
14
|
+
mkdir mongoose-app
|
|
15
|
+
cd mongoose-app
|
|
16
|
+
bun init
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
Then add Mongoose as a dependency.
|
|
22
|
+
|
|
23
|
+
```sh terminal icon="terminal"
|
|
24
|
+
bun add mongoose
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
29
|
+
In `schema.ts` we'll declare and export a simple `Animal` model.
|
|
30
|
+
|
|
31
|
+
```ts schema.ts icon="/icons/typescript.svg"
|
|
32
|
+
import * as mongoose from "mongoose";
|
|
33
|
+
|
|
34
|
+
const animalSchema = new mongoose.Schema(
|
|
35
|
+
{
|
|
36
|
+
title: { type: String, required: true },
|
|
37
|
+
sound: { type: String, required: true },
|
|
38
|
+
},
|
|
39
|
+
{
|
|
40
|
+
methods: {
|
|
41
|
+
speak() {
|
|
42
|
+
console.log(`${this.sound}!`);
|
|
43
|
+
},
|
|
44
|
+
},
|
|
45
|
+
},
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
export type Animal = mongoose.InferSchemaType<typeof animalSchema>;
|
|
49
|
+
export const Animal = mongoose.model("Animal", animalSchema);
|
|
50
|
+
```
|
|
51
|
+
|
|
52
|
+
---
|
|
53
|
+
|
|
54
|
+
Now from `index.ts` we can import `Animal`, connect to MongoDB, and add some data to our database.
|
|
55
|
+
|
|
56
|
+
```ts index.ts icon="/icons/typescript.svg"
|
|
57
|
+
import * as mongoose from "mongoose";
|
|
58
|
+
import { Animal } from "./schema";
|
|
59
|
+
|
|
60
|
+
// connect to database
|
|
61
|
+
await mongoose.connect("mongodb://127.0.0.1:27017/mongoose-app");
|
|
62
|
+
|
|
63
|
+
// create new Animal
|
|
64
|
+
const cow = new Animal({
|
|
65
|
+
title: "Cow",
|
|
66
|
+
sound: "Moo",
|
|
67
|
+
});
|
|
68
|
+
await cow.save(); // saves to the database
|
|
69
|
+
|
|
70
|
+
// read all Animals
|
|
71
|
+
const animals = await Animal.find();
|
|
72
|
+
animals[0].speak(); // logs "Moo!"
|
|
73
|
+
|
|
74
|
+
// disconnect
|
|
75
|
+
await mongoose.disconnect();
|
|
76
|
+
```
|
|
77
|
+
|
|
78
|
+
---
|
|
79
|
+
|
|
80
|
+
Let's run this with `bun run`.
|
|
81
|
+
|
|
82
|
+
```bash terminal icon="terminal"
|
|
83
|
+
bun run index.ts
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
```txt
|
|
87
|
+
Moo!
|
|
88
|
+
```
|
|
89
|
+
|
|
90
|
+
---
|
|
91
|
+
|
|
92
|
+
This is a simple introduction to using Mongoose with TypeScript and Bun. As you build your application, refer to the official [MongoDB](https://docs.mongodb.com/) and [Mongoose](https://mongoosejs.com/docs/) sites for complete documentation.
|
|
@@ -0,0 +1,234 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Use Neon Postgres through Drizzle ORM
|
|
3
|
+
sidebarTitle: Neon Drizzle with Bun
|
|
4
|
+
mode: center
|
|
5
|
+
---
|
|
6
|
+
|
|
7
|
+
[Neon](https://neon.tech/) is a fully managed serverless Postgres, separating compute and storage to offer features like autoscaling, branching and bottomless storage. Neon can be used from Bun directly using the `@neondatabase/serverless` driver or through an ORM like `Drizzle`.
|
|
8
|
+
|
|
9
|
+
Drizzle ORM supports both a SQL-like "query builder" API and an ORM-like [Queries API](https://orm.drizzle.team/docs/rqb). Get started by creating a project directory, initializing the directory using `bun init`, and installing Drizzle and the [Neon serverless driver](https://github.com/neondatabase/serverless/).
|
|
10
|
+
|
|
11
|
+
```sh terminal icon="terminal"
|
|
12
|
+
mkdir bun-drizzle-neon
|
|
13
|
+
cd bun-drizzle-neon
|
|
14
|
+
bun init -y
|
|
15
|
+
bun add drizzle-orm @neondatabase/serverless
|
|
16
|
+
bun add -D drizzle-kit
|
|
17
|
+
```
|
|
18
|
+
|
|
19
|
+
---
|
|
20
|
+
|
|
21
|
+
Create a `.env.local` file and add your [Neon Postgres connection string](https://neon.tech/docs/connect/connect-from-any-app) to it.
|
|
22
|
+
|
|
23
|
+
```txt .env.local icon="settings"
|
|
24
|
+
DATABASE_URL=postgresql://usertitle:password@ep-adj-noun-guid.us-east-1.aws.neon.tech/neondb?sslmode=require
|
|
25
|
+
```
|
|
26
|
+
|
|
27
|
+
---
|
|
28
|
+
|
|
29
|
+
We will connect to the Neon database using the Neon serverless driver, wrapped in a Drizzle database instance.
|
|
30
|
+
|
|
31
|
+
```ts db.ts icon="/icons/typescript.svg"
|
|
32
|
+
import { neon } from "@neondatabase/serverless";
|
|
33
|
+
import { drizzle } from "drizzle-orm/neon-http";
|
|
34
|
+
|
|
35
|
+
// Bun automatically loads the DATABASE_URL from .env.local
|
|
36
|
+
// Refer to: https://bun.com/docs/runtime/env for more information
|
|
37
|
+
const sql = neon(process.env.DATABASE_URL!);
|
|
38
|
+
|
|
39
|
+
export const db = drizzle(sql);
|
|
40
|
+
```
|
|
41
|
+
|
|
42
|
+
---
|
|
43
|
+
|
|
44
|
+
To see the database in action, add these lines to `index.ts`.
|
|
45
|
+
|
|
46
|
+
```ts index.ts icon="/icons/typescript.svg"
|
|
47
|
+
import { db } from "./db";
|
|
48
|
+
import { sql } from "drizzle-orm";
|
|
49
|
+
|
|
50
|
+
const query = sql`select 'hello world' as text`;
|
|
51
|
+
const result = await db.execute(query);
|
|
52
|
+
console.log(result.rows);
|
|
53
|
+
```
|
|
54
|
+
|
|
55
|
+
---
|
|
56
|
+
|
|
57
|
+
Then run `index.ts` with Bun.
|
|
58
|
+
|
|
59
|
+
```sh terminal icon="terminal"
|
|
60
|
+
bun run index.ts
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
```txt
|
|
64
|
+
[
|
|
65
|
+
{
|
|
66
|
+
text: "hello world",
|
|
67
|
+
}
|
|
68
|
+
]
|
|
69
|
+
```
|
|
70
|
+
|
|
71
|
+
---
|
|
72
|
+
|
|
73
|
+
We can define a schema for our database using Drizzle ORM primitives. Create a `schema.ts` file and add this code.
|
|
74
|
+
|
|
75
|
+
```ts schema.ts icon="/icons/typescript.svg"
|
|
76
|
+
import { pgTable, integer, serial, text, timestamp } from "drizzle-orm/pg-core";
|
|
77
|
+
|
|
78
|
+
export const authors = pgTable("authors", {
|
|
79
|
+
id: serial("id").primaryKey(),
|
|
80
|
+
title: text("name").notNull(),
|
|
81
|
+
bio: text("bio"),
|
|
82
|
+
createdAt: timestamp("created_at").notNull().defaultNow(),
|
|
83
|
+
});
|
|
84
|
+
```
|
|
85
|
+
|
|
86
|
+
---
|
|
87
|
+
|
|
88
|
+
We then use the `drizzle-kit` CLI to generate an initial SQL migration.
|
|
89
|
+
|
|
90
|
+
```sh
|
|
91
|
+
bunx drizzle-kit generate --dialect postgresql --schema ./schema.ts --out ./drizzle
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
---
|
|
95
|
+
|
|
96
|
+
This creates a new `drizzle` directory containing a `.sql` migration file and `meta` directory.
|
|
97
|
+
|
|
98
|
+
```txt File Tree icon="folder-tree"
|
|
99
|
+
drizzle
|
|
100
|
+
├── 0000_aspiring_post.sql
|
|
101
|
+
└── meta
|
|
102
|
+
├── 0000_snapshot.json
|
|
103
|
+
└── _journal.json
|
|
104
|
+
```
|
|
105
|
+
|
|
106
|
+
---
|
|
107
|
+
|
|
108
|
+
We can execute these migrations with a simple `migrate.ts` script. This script creates a new connection to the Neon database and executes all unexecuted migrations in the `drizzle` directory.
|
|
109
|
+
|
|
110
|
+
```ts migrate.ts
|
|
111
|
+
import { db } from "./db";
|
|
112
|
+
import { migrate } from "drizzle-orm/neon-http/migrator";
|
|
113
|
+
|
|
114
|
+
const main = async () => {
|
|
115
|
+
try {
|
|
116
|
+
await migrate(db, { migrationsFolder: "drizzle" });
|
|
117
|
+
console.log("Migration completed");
|
|
118
|
+
} catch (error) {
|
|
119
|
+
console.error("Error during migration:", error);
|
|
120
|
+
process.exit(1);
|
|
121
|
+
}
|
|
122
|
+
};
|
|
123
|
+
|
|
124
|
+
main();
|
|
125
|
+
```
|
|
126
|
+
|
|
127
|
+
---
|
|
128
|
+
|
|
129
|
+
We can run this script with `bun` to execute the migration.
|
|
130
|
+
|
|
131
|
+
```sh terminal icon="terminal"
|
|
132
|
+
bun run migrate.ts
|
|
133
|
+
```
|
|
134
|
+
|
|
135
|
+
```txt
|
|
136
|
+
Migration completed
|
|
137
|
+
```
|
|
138
|
+
|
|
139
|
+
---
|
|
140
|
+
|
|
141
|
+
We can now add some data to our database. Create a `seed.ts` file with the following contents.
|
|
142
|
+
|
|
143
|
+
```ts seed.ts icon="/icons/typescript.svg"
|
|
144
|
+
import { db } from "./db";
|
|
145
|
+
import * as schema from "./schema";
|
|
146
|
+
|
|
147
|
+
async function seed() {
|
|
148
|
+
await db.insert(schema.authors).values([
|
|
149
|
+
{
|
|
150
|
+
title: "J.R.R. Tolkien",
|
|
151
|
+
bio: "The creator of Middle-earth and author of The Lord of the Rings.",
|
|
152
|
+
},
|
|
153
|
+
{
|
|
154
|
+
title: "George R.R. Martin",
|
|
155
|
+
bio: "The author of the epic fantasy series A Song of Ice and Fire.",
|
|
156
|
+
},
|
|
157
|
+
{
|
|
158
|
+
title: "J.K. Rowling",
|
|
159
|
+
bio: "The creator of the Harry Potter series.",
|
|
160
|
+
},
|
|
161
|
+
]);
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
async function main() {
|
|
165
|
+
try {
|
|
166
|
+
await seed();
|
|
167
|
+
console.log("Seeding completed");
|
|
168
|
+
} catch (error) {
|
|
169
|
+
console.error("Error during seeding:", error);
|
|
170
|
+
process.exit(1);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
|
|
174
|
+
main();
|
|
175
|
+
```
|
|
176
|
+
|
|
177
|
+
---
|
|
178
|
+
|
|
179
|
+
Then run this file.
|
|
180
|
+
|
|
181
|
+
```sh terminal icon="terminal"
|
|
182
|
+
bun run seed.ts
|
|
183
|
+
```
|
|
184
|
+
|
|
185
|
+
```txt
|
|
186
|
+
Seeding completed
|
|
187
|
+
```
|
|
188
|
+
|
|
189
|
+
---
|
|
190
|
+
|
|
191
|
+
We now have a database with a schema and sample data. We can use Drizzle to query it. Replace the contents of `index.ts` with the following.
|
|
192
|
+
|
|
193
|
+
```ts index.ts icon="/icons/typescript.svg"
|
|
194
|
+
import * as schema from "./schema";
|
|
195
|
+
import { db } from "./db";
|
|
196
|
+
|
|
197
|
+
const result = await db.select().from(schema.authors);
|
|
198
|
+
console.log(result);
|
|
199
|
+
```
|
|
200
|
+
|
|
201
|
+
---
|
|
202
|
+
|
|
203
|
+
Then run the file. You should see the three authors we inserted.
|
|
204
|
+
|
|
205
|
+
```sh terminal icon="terminal"
|
|
206
|
+
bun run index.ts
|
|
207
|
+
```
|
|
208
|
+
|
|
209
|
+
```txt
|
|
210
|
+
[
|
|
211
|
+
{
|
|
212
|
+
id: 1,
|
|
213
|
+
title: "J.R.R. Tolkien",
|
|
214
|
+
bio: "The creator of Middle-earth and author of The Lord of the Rings.",
|
|
215
|
+
createdAt: 2024-05-11T10:28:46.029Z,
|
|
216
|
+
}, {
|
|
217
|
+
id: 2,
|
|
218
|
+
title: "George R.R. Martin",
|
|
219
|
+
bio: "The author of the epic fantasy series A Song of Ice and Fire.",
|
|
220
|
+
createdAt: 2024-05-11T10:28:46.029Z,
|
|
221
|
+
}, {
|
|
222
|
+
id: 3,
|
|
223
|
+
title: "J.K. Rowling",
|
|
224
|
+
bio: "The creator of the Harry Potter series.",
|
|
225
|
+
createdAt: 2024-05-11T10:28:46.029Z,
|
|
226
|
+
}
|
|
227
|
+
]
|
|
228
|
+
```
|
|
229
|
+
|
|
230
|
+
---
|
|
231
|
+
|
|
232
|
+
This example used the Neon serverless driver's SQL-over-HTTP functionality. Neon's serverless driver also exposes `Client` and `Pool` constructors to enable sessions, interactive transactions, and node-postgres compatibility. Refer to [Neon's documentation](https://neon.tech/docs/serverless/serverless-driver) for a complete overview.
|
|
233
|
+
|
|
234
|
+
Refer to the [Drizzle website](https://orm.drizzle.team/docs/overview) for more documentation on using the Drizzle ORM.
|