MyGit

denodrivers/mongo

Fork: 95 Star: 513 (更新于 2024-12-23 20:20:40)

license: MIT

Language: TypeScript .

🍃 MongoDB driver for Deno 🦕

最后发布版本: v0.33.0 ( 2024-03-26 07:16:35)

官方网址 GitHub网址

deno_mongo

deno_mongo is a MongoDB database driver developed for Deno. supports Deno Deploy as well.

ATTENTION

Deno have added the support for npm modules. so you can also use npm:mongodb driver from now.
Each of these two drivers has its own advantages and disadvantages. you can follow this issue for more details. In short:

  • if you want to use basic MongoDB operations and you don't care about stability, this driver just works.
  • if you want most of MongoDB feature working with Deno and you don't care about the possible overheads by using node compat layer, you may try the npm:mongodb driver
  • if you are using MongoDB Atlas, using atlas_sdk can be your best option.

tag Build Status license Discord server

Links

Import

Replace LATEST_VERSION with current latest version

import {
  Bson,
  MongoClient,
} from "https://deno.land/x/mongo@LATEST_VERSION/mod.ts";

Connect

const client = new MongoClient();

// Connecting to a Local Database
await client.connect("mongodb://127.0.0.1:27017");

// Connecting to a Mongo Atlas Database
await client.connect({
  db: "<db_name>",
  tls: true,
  servers: [
    {
      host: "<db_cluster_url>",
      port: 27017,
    },
  ],
  credential: {
    username: "<username>",
    password: "<password>",
    db: "<db_name>",
    mechanism: "SCRAM-SHA-1",
  },
});

// Connect using srv url
await client.connect(
  "mongodb+srv://<username>:<password>@<db_cluster_url>/<db_name>?authMechanism=SCRAM-SHA-1",
);

Access Collection

// Defining schema interface
interface UserSchema {
  _id: ObjectId;
  username: string;
  password: string;
}

const db = client.database("test");
const users = db.collection<UserSchema>("users");

Insert

const insertId = await users.insertOne({
  username: "user1",
  password: "pass1",
});

const insertIds = await users.insertMany([
  {
    username: "user1",
    password: "pass1",
  },
  {
    username: "user2",
    password: "pass2",
  },
]);

Find

const user1 = await users.findOne({ _id: insertId });

const all_users = await users.find({ username: { $ne: null } }).toArray();

// find by ObjectId
const user1_id = await users.findOne({
  _id: new ObjectId("SOME OBJECTID STRING"),
});

Count

const count = await users.countDocuments({ username: { $ne: null } });

const estimatedCount = await users.estimatedDocumentCount({
  username: { $ne: null },
});

Aggregation

const docs = await users.aggregate([
  { $match: { username: "many" } },
  { $group: { _id: "$username", total: { $sum: 1 } } },
]).toArray();

Update

const { matchedCount, modifiedCount, upsertedId } = await users.updateOne(
  { username: { $ne: null } },
  { $set: { username: "USERNAME" } },
);

const { matchedCount, modifiedCount, upsertedId } = await users.updateMany(
  { username: { $ne: null } },
  { $set: { username: "USERNAME" } },
);

Replace

const { matchedCount, modifiedCount, upsertedId } = await users.replaceOne(
  { username: "a" },
  {
    username: "user1",
    password: "pass1",
  }, // new document
);

Delete

const deleteCount = await users.deleteOne({ _id: insertId });

const deleteCount2 = await users.deleteMany({ username: "test" });

Cursor methods

const cursor = users.find();

// Skip & Limit
cursor.skip(10).limit(10);

// iterate results
for await (const user of cursor) {
  console.log(user);
}

// or save results to array (uses more memory)
const users = await cursor.toArray();

GridFS

// Upload
const bucket = new GridFSBucket(db);
const upstream = bucket.openUploadStream("test.txt");

const writer = upstream.getWriter();
writer.write(fileContents);

await writer.close();

// Download
const file = await new Response(bucket.openDownloadStream(id)).text();

Community Resources

Tools

Examples

  • deno-deploy-mongo A simple app with Deno, MongoDB and oak deployed on Deno Deploy and MongoDB Atlas
  • deno_rest A simple oak based boilerplate for RESTful apis using deno_mongo

Contributing

Local testing with Docker

  1. docker run -d -p 27017:27017 mongo
  2. deno test -A

最近版本更新:(数据更新于 2024-09-26 04:30:26)

2024-03-26 07:16:35 v0.33.0

2023-08-27 14:35:59 v0.32.0

2023-03-18 19:24:41 v0.31.2

2022-09-05 20:09:54 v0.31.1

2022-07-23 19:32:06 v0.31.0

2022-06-17 16:33:54 v0.30.1

2022-05-20 02:38:04 v0.30.0

2022-04-22 06:14:19 v0.29.4

2022-03-19 06:27:15 v0.29.3

2022-02-19 23:09:38 v0.29.2

主题(topics):

database, deno, deno-deploy, driver, mongodb, typescript

denodrivers/mongo同语言 TypeScript最近更新仓库

2025-01-18 21:38:50 chenfan0/fideo-live-record

2025-01-18 15:06:58 RSSNext/Follow

2025-01-18 13:15:01 labring/FastGPT

2025-01-18 04:09:49 bluesky-social/social-app

2025-01-17 20:54:16 lobehub/lobe-chat

2025-01-17 11:06:01 TBXark/ChatGPT-Telegram-Workers