ThinkJS MongoDB支持

2021-09-17 10:23 更新

MongoDB

ThinkJS 支持使用 MongoDB 数据库,底层使用 mongodb 模块。

配置

使用 MongoDB 数据库,需要将模型中的配置 type 改为 mongo,修改配置文件 src/common/config/db.js

export default {
  type: "mongo"
}

如果要在连接 MongoDB 服务的时候添加额外的参数,可以通过在 options 里追加,如:

export default {
  type: "mongo",
  options: {
    authSource: "admin"
  }
}

上面的配置后,连接 MongoDB 的 URL 变成类似于 mongodb://127.0.0.1:27017/?authSource=admin

更多额外的配置请见 http://mongodb.github.io/node-mongodb-native/2.0/reference/connecting/connection-settings/

创建模型

可以通过命令 thinkjs model [name] --mongo 来创建模型,如:

thinkjs model user --mongo

执行完成后,会创建文件 src/common/model/user.js。如果想创建在其他模块下,需要带上具体的模块名。如:

thinkjs model home/user --mongo

会在 home 模块下创建模型文件,文件为 src/home/model/user.js

模型继承

模型需要继承 think.model.mongo 类,如果当前类不是继承该类,需要手动修改。

ES6 语法

export default class extends think.model.mongo {

}

动态创建类的方式

module.exports = think.model("mongo", {

})

CURD 操作

CURD 操作和 Mysql 中接口相同,具体请见 模型 -> 介绍

创建索引

mongo 模型可以配置索引,在增删改查操作之前模型会自动去创建索引,配置放在 indexes 属性里。如:

export default class extends think.model.mongo {
  init(...args){
    super.init(...args);
    //配置索引
    this.indexes = { 

    }
  }
}

单字段索引

export default class extends think.model.mongo {
  init(...args){
    super.init(...args);
    //配置索引
    this.indexes = { 
      name: 1
    }
  }
}

唯一索引

通过 $unique 来指定为唯一索引,如:

export default class extends think.model.mongo {
  init(...args){
    super.init(...args);
    //配置索引
    this.indexes = { 
      name: {$unique: 1}
    }
  }
}

多字段索引

可以将多个字段联合索引,如:

export default class extends think.model.mongo {
  init(...args){
    super.init(...args);
    //配置索引
    this.indexes = { 
      email: 1
      test: {
        name: 1,
        title: 1,
        $unique: 1
      }
    }
  }
}

获取索引

可以通过方法 getIndexes 获取创建的索引。如:

export default class extends think.controller.base {
  async indexAction(){
    let model = this.model("user");
    let indexes = await model.getIndexes();
  }
}

aggregate

可以通过 aggregate 方法进行混合操作。如:

export default class extends think.model.mongo {
  match(){
    return this.aggregate([
      {$match: {status: "A"}},
      {$group: {_id: "$cust_id", total: {$sum: "$amount"}}}
    ]);
  }
}

具体请见 https://docs.mongodb.org/manual/core/aggregation-introduction/

MapReduce

可以通过 mapReduce 方法进行 MapReduce 操作。如:

export default class extends think.model.mongo {
  execMapReduce(){
    let map = () => {
      emit(this.cust_id, this.amount);
    }
    let reduce = (key, values) => {
      return Array.sum(values);
    }
    return this.mapReduce(map, reduce, {
      query: {status: "A"},
      out: "order_totals"
    })
  }
}

具体请见 https://docs.mongodb.org/manual/core/aggregation-introduction/#map-reduce

以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号