当前位置:网站首页>Node の MongoDB Driver
Node の MongoDB Driver
2022-07-05 09:26:00 【InfoQ】
序
MongoDB
Compass
MongoDB
- mongodb: MongoDB有一个基础库
mongodb
(Node.js MongoDB Driver)
- Mongoose: 现在主流使用的库,在代码量上更优,只需增删改查推荐
mongodb
下载
yarn add mongodb
mongodb
data:image/s3,"s3://crabby-images/355a9/355a98dc61b8bd75fe8003cc006cfceb4d46e73c" alt=""
连接
mongodb
MongoClient
data:image/s3,"s3://crabby-images/8c560/8c56019173bc76cb44c9a429b7f0dc2487089564" alt=""
const MongoClient = require('mongodb').MongoClient;
const baseUrl = 'mongodb://127.0.0.1:27017/mongodbTest'
function TestConnect() {
MongoClient.connect(baseUrl, function(err, db) {
if (err) throw err;
console.log("数据库已创建!");
db.close();
});
}
data:image/s3,"s3://crabby-images/a4ee6/a4ee65e24f182a8ecb6acae1363ceeb6e9982c53" alt=""
mongodbTest
compass
data:image/s3,"s3://crabby-images/cd8b0/cd8b0729e1a72c64621b508842c3456b9b883b97" alt=""
data:image/s3,"s3://crabby-images/9d0cf/9d0cfd307b69d679aa6bd828aec3b461f3e9eddb" alt=""
data:image/s3,"s3://crabby-images/d0c42/d0c42ebb278625fea317e69c89b23c6b0b495e4a" alt=""
data:image/s3,"s3://crabby-images/2255c/2255c7630af231d655e4b1fc513e22e191c9e22d" alt=""
data:image/s3,"s3://crabby-images/39e40/39e402c2bfa95e1ef4afd91967fc814db60d50a9" alt=""
MongoClient.db
const baseUrl = 'mongodb://127.0.0.1:27017'
// 创建对象
const client = new MongoClient(baseUrl);
async function TestConnect() {
try {
// 连接到数据库
await client.connect();
// 使用之前手动创建的mongodbTest数据库
const db = await client.db('mongodbTest');
console.log(db.databaseName)
// 创建一个新的集合 (如果是代码新建的数据库,那么必须创建一个集合)
db.createCollection('collection01')
} catch(e) {
console.log(e)
await client.close();
}
}
module.exports = { TestConnect }
获取集合列表
collections
collectionName
// 连接到数据库
await client.connect();
// 使用之前手动创建的mongodbTest数据库
const db = await client.db('mongodbTest');
// 获取当前数据库下所有集合
let collections = await db.collections();
// 打印集合名称
collections.forEach(item=>{
console.log(item.collectionName)
})
data:image/s3,"s3://crabby-images/400fb/400fbb259f52a7d3de105b58aa1320920aa53f55" alt=""
data:image/s3,"s3://crabby-images/62142/621420e58437cd04fcc8e08bdab9cf0bf88d0caf" alt=""
创建集合并插入数据
data:image/s3,"s3://crabby-images/ce73f/ce73ff7e7dbded347bcc5fa2c2881ba13628535f" alt=""
// 创建新集合
db.createCollection('collection03', { autoIndexId: true }, (err, res)=>{
if (err) console.log('集合创建失败');
console.log(res.collectionName) // collection03
})
insertOne
// 使用集合collection03
let c3 = db.collection('collection03');
// 定义文档
let doc = {
name: '张三',
age: 18,
hobby: '打李四',
}
// 将文档插入集合
const result = await c3.insertOne(doc);
data:image/s3,"s3://crabby-images/579a3/579a370528702a44f1abffc2602ceccd4990b870" alt=""
data:image/s3,"s3://crabby-images/bda3e/bda3e31e0ef22356f16bee304222e1352b2e5058" alt=""
- insert: 将单个文档或文档数组插入MongoDB。如果传入的文档不包含\u id字段,驱动程序将向缺少该字段的每个文档中添加一个,从而改变文档
- insertMany: 将文档数组插入MongoDB。如果传入的文档不包含\u id字段,驱动程序将向缺少该字段的每个文档中添加一个,从而改变文档
- insertOne: 将单个文档插入MongoDB。如果传入的文档不包含\u id字段,驱动程序将向缺少该字段的每个文档中添加一个,从而改变文档
let doc = [
{
name: '李四',
age: 18,
hobby: '打王五',
},
{
name: '王五',
age: 18,
hobby: '打张三',
},
]
// 将文档插入集合
const result = await c3.insertMany(doc);
data:image/s3,"s3://crabby-images/841a1/841a17a056eebd26db5ddbd092d3f519c7c800ee" alt=""
data:image/s3,"s3://crabby-images/3b1b8/3b1b8373b297258ba32d3ba53eeb26f33d032d8f" alt=""
读取集合中的数据
MongoDB
find
data:image/s3,"s3://crabby-images/5d010/5d010e95751ecedb4b475ac1b0960d2da7e2d87b" alt=""
// 读取集合中数据
const res = await c3.find().toArray();
console.log(res)
data:image/s3,"s3://crabby-images/91fef/91fefc79e6b877c9f0c0ec4bc29e536909816754" alt=""
find
projection
MongoServerError: Cannot do inclusion on field name in exclusion projection
_id
age
// 读取集合中数据
const res = await c3.find({}, {
projection: { _id: 0, age: 0 }
}).toArray();
console.log(res)
data:image/s3,"s3://crabby-images/07ca3/07ca3cddb28f45903f32e86002cd5eb1813226fe" alt=""
find
{}
// 读取集合中数据
const res = await c3.find({
name: /张/
}, {
projection: { _id: 0, age: 0 }
}).toArray();
console.log(res)
data:image/s3,"s3://crabby-images/86b13/86b131e817fff78022dc729fc429690779509e6e" alt=""
删除集合信息
data:image/s3,"s3://crabby-images/28d80/28d809a611d820df0a99cadb8f233e99902904fd" alt=""
// 读取集合中数据
const res = await c3.deleteOne({
name: /张/
});
console.log(res) // { acknowledged: true, deletedCount: 1 }
data:image/s3,"s3://crabby-images/b486a/b486ac1962616fd280387eb30c9d0d8a4428a53e" alt=""
更新集合
data:image/s3,"s3://crabby-images/23879/23879840fe646b78b5f8cf84b6d11cc7731200c4" alt=""
// 读取集合中数据
let newvalue = { $set: { hobby: '打李四' } }
const res = await c3.updateOne({
name: /王/
}, newvalue);
console.log(res)
data:image/s3,"s3://crabby-images/fe908/fe90812d4dc8524a43d9b84d14d4c9ee762ff18f" alt=""
边栏推荐
- 一篇文章带你走进cookie,session,Token的世界
- [code practice] [stereo matching series] Classic ad census: (5) scan line optimization
- Rebuild my 3D world [open source] [serialization-2]
- Driver's license physical examination hospital (114-2 hang up the corresponding hospital driver physical examination)
- nodejs_ fs. writeFile
- Applet global style configuration window
- [beauty of algebra] singular value decomposition (SVD) and its application to linear least squares solution ax=b
- Thermometer based on STM32 single chip microcomputer (with face detection)
- Attention is all you need
- Applet (global data sharing)
猜你喜欢
[beauty of algebra] singular value decomposition (SVD) and its application to linear least squares solution ax=b
Nodejs modularization
生成对抗网络
信息与熵,你想知道的都在这里了
3D reconstruction open source code summary [keep updated]
【ManageEngine】如何利用好OpManager的报表功能
高性能Spark_transformation性能
Unity SKFramework框架(二十四)、Avatar Controller 第三人称控制
[ctfhub] Title cookie:hello guest only admin can get flag. (cookie spoofing, authentication, forgery)
[ManageEngine] how to make good use of the report function of OpManager
随机推荐
【PyTorch Bug】RuntimeError: Boolean value of Tensor with more than one value is ambiguous
微信小程序获取住户地区信息
Newton iterative method (solving nonlinear equations)
Confusion matrix
Unity skframework framework (XXII), runtime console runtime debugging tool
Information and entropy, all you want to know is here
22-07-04 Xi'an Shanghao housing project experience summary (01)
[ctfhub] Title cookie:hello guest only admin can get flag. (cookie spoofing, authentication, forgery)
Wxss template syntax
图神经网络+对比学习,下一步去哪?
Creation and reference of applet
Alibaba cloud sends SMS verification code
2311. 小于等于 K 的最长二进制子序列
Kotlin introductory notes (III) kotlin program logic control (if, when)
2309. The best English letters with both upper and lower case
Jenkins Pipeline 方法(函数)定义及调用
22-07-04 西安 尚好房-项目经验总结(01)
C # image difference comparison: image subtraction (pointer method, high speed)
Thermometer based on STM32 single chip microcomputer (with face detection)
太不好用了,长文章加图文,今后只写小短文