mongoose学习笔记一

名词解释

Schema: 一种以文件形式存储的数据库模型骨架,不具备数据库的操作能力

Model: 由Schema编译而成的假想(fancy)构造器,具有抽象属性和行为。Model的每一个实例(instance)就是一个documentdocument可以保存到数据库和从数据库返回。

Instance: 由Model创建的实例。

概念解析

SQL术语/概念 MongoDB术语/概念 解释/说明
database database
table collection 数据库表/集合
row document 数据记录行/文档
column field 数据字段/域
index index 索引
table joins 表连接,MongoDB不支持
primary key primary key 主键,MongoDB自动将_id字段设置为主键

定义Schema

mongoose中任何任何事物都是从Schema开始的。每一个Schema对应MongoDB中的一个集合(collection)。Schema中定义了集合中文档(document)的样式。

var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var blogSchema = new Schema({
  title:  String,
  author: String,
  body:   String,
  comments: [{ body: String, date: Date }],
  date: { type: Date, default: Date.now },
  hidden: Boolean,
  meta: {
    votes: Number,
    favs:  Number
  }
});

如果之后想要在Schema中添加键,可以使用Schema#add方法。

创造一个model

为了使用schema定义,我们需要转换blogSchema为一个Model。使用mongoose.model(modelName, schema)

var BlogModel = mongoose.model('Blog', blogSchema);
// 开始吧!

实例方法

Model的实例是document。实例有很多内置的方法,我们也可以给实例自定义方法。

var animalSchema = new Schema({ name: String, type: String });

animalSchema.methods.findSimilarTypes = function (cb) {
   
  return this.model('Animal').find({ type: this.type }, cb);
}

现在所有的动物实例有findSimilarTypes方法。

var AnimalModel = mongoose.model('Animal', animalSechema);
var dog = new AnimalModel({ type: 'dog' });
dog.findSimilarTypes(function (err, dogs) {
   
  console.log(dogs); // woof
});

重写一个默认的实例方法可能会导致不期待的结果。

Statics

Model添加一个静态方法也是简单的。

animalSchema.statics.findByName = function (name, cb) {
   
  this.find({ name: new RegExp(name, 'i') }, cb);
}
var AnimalModel = mongoose.model('Animal', animalSchema);
AnimalModel.findByName('fido', function (err, animals) {
   
  console.log(animals);
});

methods和statics的区别

区别就是一个给Model添加方法(statics),一个给实例添加方法(methods)。下面是stackOverflow的两个答案。

答案一

答案二

索引

MongoDB支持二级索引,定义索引有两种方式

  • 路径级别
  • schema级别
var animalSchema = new Schema({
  name: String,
  type: String,
  tags: { type: [String], index: true } // field level
});
animalSchema.index({ name: 1, type: -1 }); // schema level, 1是正序,-1是倒序

如果要建立复合索引的话,在schema级别建立是必要的。

索引或者复合索引能让搜索更加高效,默认索引就是主键索引ObjectId,属性名为_id

数据库中主要的就是CRUD操作,建立索引可以提高查询速度。但是过多的索引会降低CUD操作。深度好文如下

http://www.cnblogs.com/huangxincheng/archive/2012/02/29/2372699.html

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值