- [使用 ES6 的语法继承该类](#%E4%BD%BF%E7%94%A8-es6-%E7%9A%84%E8%AF%AD%E6%B3%95%E7%BB%A7%E6%89%BF%E8%AF%A5%E7%B1%BB)
- [使用普通方式继承该类](#%E4%BD%BF%E7%94%A8%E6%99%AE%E9%80%9A%E6%96%B9%E5%BC%8F%E7%BB%A7%E6%89%BF%E8%AF%A5%E7%B1%BB)
think.model.mongo
继承类 think.model.base。
export default class extends think.model.mongo {
getList(){
}
}
module.exports = think.model('mongo', {
getList: function(){
}
})
设置字段,如:
export default class extends think.model.mongo {
init(...args){
super.init(...args);
//设置字段
this.fields = {
name: {
type: 'string'
},
pwd: {
type: 'string'
}
}
}
}
注
:目前框架并不会对字段进行检查。
设置字段索引,数据操作之前会自动创建索引。
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
}
}
}
}
主键名,默认为 _id
,可以通过 this.getPk
方法获取。
mongo 模型中的 where 条件设置和关系数据库中不太一样。
export default class extends think.model.mongo {
where1(){
return this.where({ type: "snacks" }).select();
}
}
export default class extends think.model.mongo {
where1(){
return this.where({ type: 'food', price: { $lt: 9.95 } }).select();
}
}
export default class extends think.model.mongo {
where1(){
return this.where({
$or: [ { qty: { $gt: 100 } }, { price: { $lt: 9.95 } } ]
}).select();
}
where2(){
return this.where({
type: 'food',
$or: [ { qty: { $gt: 100 } }, { price: { $lt: 9.95 } } ]
}).select();
}
}
export default class extends think.model.mongo {
where1(){
return this.where( {
producer:
{
company: 'ABC123',
address: '123 Street'
}
}).select();
}
where2(){
return this.where({ 'producer.company': 'ABC123' } ).select();
}
}
export default class extends think.model.mongo {
where1(){
return this.where({ type: { $in: [ 'food', 'snacks' ] } }).select();
}
}
更多文档请见 https://docs.mongodb.org/manual/reference/operator/query/#query-selectors。
return
{Promise}获取操作当前表的句柄。
export default class extends think.model.mongo {
async getIndexes(){
let collection = await this.collection();
return collection.indexes();
}
}
聚合查询。具体请见 https://docs.mongodb.org/manual/core/aggregation-introduction/。
mapReduce 操作,具体请见 https://docs.mongodb.org/manual/core/map-reduce/。
indexes
{Object} 索引配置options
{Object}创建索引。
return
{Promise}获取索引。