1

原文链接:Mongoose

前言

学数据库肯定需要知道怎么连接后台
Mongoose 是用来方便连接 MongoDBnode 的一个工具包
是时候学习一波

nodejs连接MongoDB

连接数据库前需要先打开数据库 MongoDB

yarn add mongoose  // 安装 mongoose 依赖
let mongoose = require("mongoose");
let db = mongoose.connect("mongodb://127.0.0.1:27107/test");
db.connection.on("error", function (error) {
    console.log("数据库连接失败:" + error);
});
db.connection.on("open", function () {
    console.log("------数据库连接成功!------");
});

操纵数据

  1. Schema:数据库集合的模型骨架,或者是数据属性模型传统意义的表结构。

  2. Model :通过Schema构造而成,除了具有Schema定义的数据库骨架以外,还可以具体的操作数据库。

  3. Entity:通过Model创建的实体,它也可以操作数据库。

但Model比Entity更具操作性。

let mongoose = require("mongoose");
let db = mongoose.connect("mongodb://127.0.0.1:27017/test");
let TestSchema = new mongoose.Schema({  // 使用 Schema 创建集合结构(表结构)
    name : { type:String },
    age  : { type:Number, default:0 },
    email: { type:String },
    time : { type:Date, default:Date.now }
});
let TestModel = db.model("test1", TestSchema );  // test1 集合使用 Schema 结构,若不存在 test1 集合,则创建
let TestEntity = new TestModel({  // 使用 TestModel 新建一个数据
    name : "helloworld",
    age  : 28,
    email: "helloworld@qq.com"
});
TestEntity.save(function(error,doc){  // 保存数据于 test1 
  if(error){
     console.log("error :" + error);
  }else{
     console.log(doc);
  }
});

Model增删查改

let TestSchema = new mongoose.Schema({
    name : { type:String },
    age  : { type:Number, default:0 },
    email: { type:String },
    time : { type:Date, default:Date.now }
});
let TestModel = db.model("test1", TestSchema);  
// let TestModel = db.model("test1", new mongoose.Schema());
// 集合结构为空的话,不能插入数据  

  • Model方法 create

    TestModel.create({ name:"model_create", age:26}, function(error,doc){
       if(error) {
           console.log(error);
       } else {
           console.log(doc);
       }
    });
  • entity方法 save

let Entity = new TestModel({name:"entity_save",age: 27});

Entity.save(function(error,doc) {
    if(error) {
        console.log(error);
    } else {
        console.log(doc);
    }
});

Model.remove(查询条件,callback);

let conditions = {name: 'helloworld'};
TestModel.remove(conditions, function(error){
    if(error) {
        console.log(error);
    } else {
        console.log('Delete success!');
    }
});

Model.update(查询条件,更新对象,callback)

var conditions = {name : 'test_update'};
var update = {$set : { age : 16 }};  // $set 表示只修改 age,否则全覆盖
TestModel.update(conditions, update, function(error){
    if(error) {
        console.log(error);
    } else {
        console.log('Update success!');
    }
});

Model.find({}, function(error, docs));
若第一个参数为空对象,则 docs 为所有数据

TestModel.find({ "age": 28 }, function (error, docs) {
  if(error){
    console.log("error :" + error);
  }else{
    console.log(docs); //docs: age为28的所有文档
  }
}); 

结语

学习源: Mongoose
真是通俗易懂的操作呀
MongoDB 好感度 up up up
?


塞尔达真好玩
255 声望5 粉丝