📅  最后修改于: 2023-12-03 15:22:14.727000             🧑  作者: Mango
MongoDB 是 NoSQL 中的一种,它使用文档来存储数据,采用了面向集合编程的概念。与传统的关系型数据库相比,MongoDB 具有更高的灵活性和扩展性,使其成为当前流行的数据库之一。
在 Node.js 中使用 MongoDB,我们需要遵循一些约束来保证程序的稳定性和可靠性。以下为你介绍这些约束。
在使用 MongoDB 之前,我们首先需要在本地安装 MongoDB 数据库。你可以从官方网站上下载对应版本的 MongoDB。
安装 Node.js 驱动程序有两种方式:通过 npm 进行安装或手动下载和安装。
使用 npm 进行安装:
npm install mongodb --save
安装完成后,你可以将其引入你的 Node.js 项目中:
const MongoClient = require('mongodb').MongoClient;
通过 Node.js 驱动程序连接 MongoDB 数据库非常简单。首先,我们需要创建一个 MongoClient 对象,然后使用该对象连接 MongoDB 数据库。
const MongoClient = require('mongodb').MongoClient;
const url = 'mongodb://localhost:27017';
const dbName = 'mydb';
MongoClient.connect(url, function(err, client) {
console.log("Connected successfully to server");
const db = client.db(dbName);
// 关闭数据库连接
client.close();
});
在 MongoDB 中,集合相当于关系型数据库中的表。创建集合也非常简单:
db.createCollection('users', function(err, res) {
console.log("Collection created!");
});
插入文档也非常容易:
const collection = db.collection('users');
const user = { name: "John", age: 28 };
collection.insertOne(user, function(err, res) {
console.log("1 document inserted");
});
更新文档需要使用 MongoDB 中的 update() 方法:
const collection = db.collection('users');
const query = { name: "John" };
const newValues = { $set: { age: 29 }};
collection.updateOne(query, newValues, function(err, res) {
console.log("1 document updated");
});
删除文档需要使用 MongoDB 中的 deleteOne() 或 deleteMany() 方法:
const collection = db.collection('users');
const query = { age: { $gt: 25 } };
collection.deleteMany(query, function(err, obj) {
console.log(obj.result.n + " documents deleted");
});
查询文档的方法非常多。下面是一些示例:
const collection = db.collection('users');
const query = { age: { $gt: 25 } };
// 查询全部文档
collection.find({}).toArray(function(err, result) {
console.log(result);
});
// 查询指定字段
collection.find({}, { projection: { _id: 0, name: 1, age: 1 } }).toArray(function(err, result) {
console.log(result);
});
// 查询单个文档
collection.findOne(query, function(err, result) {
console.log(result);
});
// 排序
collection.find({}, { sort: { age: -1 } }).toArray(function(err, result) {
console.log(result);
});
// 分页
const pageNo = 2;
const pageSize = 10;
const limit = pageSize;
const skip = (pageNo - 1) * pageSize;
collection.find(query).limit(limit).skip(skip).toArray(function(err, result) {
console.log(result);
});
使用 Node.js 的 MongoDB 驱动程序来操作 MongoDB 是简单而方便的。遵循上述约束,你可以轻松地连接和操作 MongoDB 数据库,实现数据的存储和查询。如果你愿意深入了解相关知识,请继续深入学习。