node[18]-mongodb-node增删查改

 2018-11-16  nodejs  nodejs 前端  3  评论 字数统计: 804(字) 阅读时长: 4(分)

1
> npm install --save mongodb
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
//mongodb 3以上写法
const MongoClient = require('mongodb').MongoClient;

//TodoApp是一个数据库名字,mongo中不需要创建数据库
MongoClient.connect('mongodb://localhost:27017/TodoApp',(err,client)=>{
    if(err){
      return console.log('Unable to connect to MongoDB server');
    }
    console.log('Connect to MongoDB server');
  const db = client.db('TodoApp');

  //插入数据
  db.collection('Todos').insertOne({
    text:'Something to do',
    completed:false
  },(err,result)=>{
    if(err){
        return console.log('unable to insert todo',err);
    }
        console.log(JSON.stringify(result.ops,undefined,2));
  });
//关闭客户端
  client.close();

});

id

插入一个对象的时候,会自动的产生一个随机的id。id包含了时间戳和机器识别码。
我们可以借助与mongo的方法,为我们产生一个随机数。

1
2
3
4
5
const {MongoClient,ObjectID} = require('mongodb');
var obj = new ObjectID();
console.log(obj);
//返回时间
console.log(obj.getTimestamp());

参考资料:
MongoDB Node.js Driver Documentation
node-mongodb-native

查询

原始数据:

1
2
3
4
5
6
7
8
9
10
11
12
[
  {
    "_id": "5bee9e3794c5f22eb989f6eb",
    "text": "Something to do",
    "completed": false
  },
  {
    "_id": "5beeaf0a2d48eb2b7c90758f",
    "text": "Something to do",
    "completed": true
  }
]

js代码:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
const {MongoClient,ObjectID} = require('mongodb');

MongoClient.connect('mongodb://localhost:27017/TodoApp',(err,client)=>{
    if(err){
      return console.log('Unable to connect to MongoDB server');
    }
    console.log('Connect to MongoDB server');
  const db = client.db('TodoApp');

  //返回所有document
  db.collection('Todos').find().toArray().then((docs)=>{
    console.log('Todos');
    console.log(JSON.stringify(docs,undefined,2));
  },(err)=>{
    console.log('unable to fetch todos', err);
  })

  client.close();
});

执行代码返回:

1
2
3
4
5
6
7
8
9
10
11
12
[
  {
    "_id": "5bee9e3794c5f22eb989f6eb",
    "text": "Something to do",
    "completed": false
  },
  {
    "_id": "5beeaf0a2d48eb2b7c90758f",
    "text": "Something to do",
    "completed": true
  }
]

筛选

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
const {MongoClient,ObjectID} = require('mongodb');

MongoClient.connect('mongodb://localhost:27017/TodoApp',(err,client)=>{
    if(err){
      return console.log('Unable to connect to MongoDB server');
    }
    console.log('Connect to MongoDB server');
  const db = client.db('TodoApp');
  db.collection('Todos').find({completed:true}).toArray().then((docs)=>{
    console.log('Todos');
    console.log(JSON.stringify(docs,undefined,2));
  },(err)=>{
    console.log('unable to fetch todos', err);
  })

  client.close();

});

执行代码返回:

1
2
3
4
5
6
7
[
  {
    "_id": "5beeaf0a2d48eb2b7c90758f",
    "text": "Something to do",
    "completed": true
  }
]

筛选id

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
const {MongoClient,ObjectID} = require('mongodb');

MongoClient.connect('mongodb://localhost:27017/TodoApp',(err,client)=>{
    if(err){
      return console.log('Unable to connect to MongoDB server');
    }
    console.log('Connect to MongoDB server');
  const db = client.db('TodoApp');
  db.collection('Todos').find({
    new ObjectID('5beeaf0a2d48eb2b7c90758f')
  }).toArray().then((docs)=>{
    console.log('Todos');
    console.log(JSON.stringify(docs,undefined,2));
  },(err)=>{
    console.log('unable to fetch todos', err);
  })

  client.close();

});

执行代码返回:

1
2
3
4
5
6
7
[
  {
    "_id": "5beeaf0a2d48eb2b7c90758f",
    "text": "Something to do",
    "completed": true
  }
]

删除document

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
const {MongoClient,ObjectID} = require('mongodb');

MongoClient.connect('mongodb://localhost:27017/TodoApp',(err,client)=>{
    if(err){
      return console.log('Unable to connect to MongoDB server');
    }
    console.log('Connect to MongoDB server');
  const db = client.db('TodoApp');
//  db.collection('Todos').deleteMany({text:'mike'});  删除全部

//删除一个
  // db.collection('Todos').deleteOne({text:'mike'}).then((result)=>{
  //     console.log(result);
  // });

//删除并返回对象
  db.collection('Todos').findOneAndDelete({text:'mike'}).then((result)=>{
      console.log(result);
  });

  client.close();

});

更新

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
const {MongoClient,ObjectID} = require('mongodb');

MongoClient.connect('mongodb://localhost:27017/TodoApp',(err,client)=>{
    if(err){
      return console.log('Unable to connect to MongoDB server');
    }
    console.log('Connect to MongoDB server');
  const db = client.db('TodoApp');

//查找并更新
  db.collection('Todos').findOneAndUpdate({text:'mike'},{
    $set:{
      completed:false       //设置更改
    }
  },{
    returnOriginal:false  //返回的结果为更新后的值。
  }).then((result)=>{
    console.log(result); //打印跟新结果
  });

  client.close();
});

 

郑建勋(jonson)区块链工程师 & Web工程师

灾难总是接踵而至,这正是世间的常理。你以为只要哭诉一下,就会有谁来救你吗?如果失败了,就只能说明我不过是如此程度的男人。

Mongoose 是一个在 Node.js 中操作 MongoDB 数据库的非常流行的 ODM(对象文档映射)工具。下面是一个简单的示例,展示了如何使用 Mongoose 连接 MongoDB,并进行增删查改操作。 首先,你需要安装 `mongoose` 模块: ``` npm install mongoose ``` 然后,创建一个 `models/user.js` 文件,定义一个用户模型: ```javascript const mongoose = require('mongoose'); const UserSchema = new mongoose.Schema({ name: String, age: Number, email: String }); const User = mongoose.model('User', UserSchema); module.exports = User; ``` 接下来,在你的 `app.js` 文件中,连接 MongoDB 数据库并使用上面定义的用户模型: ```javascript const mongoose = require('mongoose'); const User = require('./models/user'); mongoose.connect('mongodb://localhost/myapp', { useNewUrlParser: true, useUnifiedTopology: true }); const db = mongoose.connection; db.on('error', console.error.bind(console, 'connection error:')); db.once('open', function() { console.log('Connected to MongoDB'); // 在这里进行增删查改操作 }); ``` 现在,你可以在 `db.once` 的回调函数中进行增删查改操作了。以下是一些示例代码: 1. 添加用户 ```javascript const user = new User({ name: 'John Doe', age: 25, email: 'john.doe@example.com' }); user.save(function(err, user) { if (err) { console.error(err); } else { console.log('User added: ', user); } }); ``` 2. 查询用户 ```javascript // 查询所有用户 User.find(function(err, users) { if (err) { console.error(err); } else { console.log('All users: ', users); } }); // 根据条件查询用户 User.find({ age: { $gte: 18 } }, function(err, users) { if (err) { console.error(err); } else { console.log('Adult users: ', users); } }); // 根据 ID 查询用户 User.findById('1234567890', function(err, user) { if (err) { console.error(err); } else { console.log('User by ID: ', user); } }); ``` 3. 更新用户 ```javascript User.findByIdAndUpdate('1234567890', { age: 26 }, function(err, user) { if (err) { console.error(err); } else { console.log('User updated: ', user); } }); ``` 4. 删除用户 ```javascript User.findByIdAndDelete('1234567890', function(err) { if (err) { console.error(err); } else { console.log('User deleted'); } }); ``` 以上是一个简单的示例,你可以根据你的业务需求进行更复杂的操作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值