全栈工程师 08 笔记

Node.js操作MongoDB数据库(增、删、改、查)

  1. 先安装组件

mongodb模块:https://www.npmjs.com/package/mongodb
mongoose模块:https://www.npmjs.com/package/mongoose
Node.js 官方自带一套MongoDB的组件
这里我们采用mongoose 来对MongoDB数据库进行操作,但操作Mongoose必须先把MongoDB安装上

    安装mongodb模块
     npm install mongodb --save
    注:--save参数:将mongodb添加到package.json中,为了项目合并时,所需模块,
    不需要进行模块包的合并,使用 npm install package.json 里的所又模块都会安装
    
    安装mongoose模块
     npm install mongoose
     mongoose 是操作mongodb数据库的客户端;`mongoose`需要`mongodb`的支持
  1. 创建目录开启数据库
    mkdir /home/jingyue/mongodb/data_db

     /home/jingyue/mongodb/bin/mongod --dbpath=/home/scort/mongodb/data_db
    
  2. 插入数据
    // 引入mongoose模块
    var mongoose = require('mongoose');
    //创建链接
    var db = mongoose.createConnection('mongodb://127.0.0.1:27017/user');
    //定义格式
    var monSchema = new mongoose.Schema({
    name:{type:String,default:'name'},
    age:{type:Number}
    });
    //创建表
    var monModel = db.model('user', monSchema);
    //要插入内容
    var content = {
    name : "阿文",
    age : 18
    };
    //初始化model
    var monInsert = new monModel(content);
    //执行插入
    monInsert.save(function(err, result){
    if(err){
    console.log(err);
    }else{
    console.log('写入数据成功');
    }
    //关闭连接
    db.close();
    });

  3. 删除数据
    // 引入mongoose模块
    var mongoose = require('mongoose');
    //创建链接
    var db = mongoose.createConnection('mongodb://127.0.0.1:27017/user');
    //定义格式
    var monSchema = new mongoose.Schema({
    name:{type:String,default:'name'},
    age:{type:Number}
    });
    //定义model 指定表名
    var monModel = db.model('user', monSchema);

    //条件
     var where = {name:"阿文"};
    
    //执行删除
     monModel.remove(where, function(err){
       if(err){
         console.log(err);
       }else{
         console.log('删除成功');
       }
      //关闭连接
       db.close();
     });
    
  4. 更新数据
    // 引入mongoose模块
    var mongoose = require('mongoose');
    //创建链接
    var db = mongoose.createConnection('mongodb://127.0.0.1:27017/user');
    //定义格式
    var monSchema = new mongoose.Schema({
    name:{type:String,default:'name'},
    age:{type:Number}
    });

    //定义model 指定表名
     var monModel = db.model('user', monSchema);
    
    //条件
     var where = {name:'小月月'};
    
    //设置新值
     var newData = {$set : {age:19, name:"文文"}};
    
    //执行删除
     monModel.update(where, newData, function(err, result){
        if(err){
           console.log(err);
        }else{
           console.log('更新成功');
        }
    
       //关闭连接
        db.close();
     });
    
  5. 查询数据
    // 引入mongoose模块
    var mongoose = require('mongoose');
    //创建链接
    var db = mongoose.createConnection('mongodb://127.0.0.1:27017/user');
    //定义格式
    var monSchema = new mongoose.Schema({
    name:{type:String,default:'name'},
    age:{type:Number}
    });

    //定义model 指定表名
     var monModel = db.model('user', monSchema);
    
    //条件
     var where = {name:"阿文"};
    
    //指定要查出来的字段
     var fields = {name:1, age:1};
    
    //查询
     monModel.find(where,fields, function(err, result){
         if(err){
           console.log(err);
         }else{
           console.log(result);
         }
    
         //关闭连接
         db.close();
     });
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本课重点:学习Node.js连接MongoDB数据库操作,并实现基本的数据库增、删、改、查操作。 1.安装Mong...
    疯范儿阅读 1,111评论 0 0
  • 安装 npm install mongodnpm install mongoose 定义数据模型 var Blog...
    ZGKzm阅读 3,717评论 0 0
  • MongoDB https://www.npmjs.com mongod --dbpath=/data --por...
    zy01阅读 1,209评论 0 0
  • 没有批评,你的人生也就这样了。不是我危言耸听,没有批评,有两种理解。1、完美无瑕;2、不值得被批评了。前者你永远不...
    语竭词穷阅读 9,119评论 1 0
  • 我和老爸夜里又喝酒了 似乎父子独处时都在夜里喝酒时 二十多年来,他没有对我说过一句话 但我被他打过 被他带去理发,...
    郑雨神阅读 1,579评论 0 1