Mongoose学习全面理解(推荐)(2)

var newUser = new User({ name: 'Simon Holmes', email: 'simon@theholmesoffice.com', lastLogin : Date.now() }).save( function( err ){ if(!err){ console.log('User saved!'); } });

上面的代码创建了一个模型实例,然后进行保存。我们有一个更为简介的方式来完成这项工作,就是使用Model.create()方法:

User.create({ name: 'Simon Holmes', email: 'simon@theholmesoffice.com', lastLogin : Date.now() }, function( err, user ){ if(!err){ console.log('User saved!'); console.log('Saved user name: ' + user.name); console.log('_id of saved user: ' + user._id); } });

三、查找数据和读取数据的方法

1.使用QueryBuilder接口来查找数据

先看看下面的代码:

var myQuery = User.find({'name' : 'Simon Holmes'}); myQuery.where('age').gt(18); myQuery.sort('-lastLogin'); myQuery.select('_id name email'); myQuery.exec(function (err, users){ if (!err){ console.log(users); // output array of users found } });

代码中,我们查找名字为"Simon Holmes",并且年龄大于18岁,查找结果根据lastLogin降序排列,只获取其中的_id, name, email三个字段的值,上面的代码只有在调用exec方法后才真正执行数据库的查询。

当然我们可以使用链式的方式来改写上面的代码,代码会更加简洁:

User.find({'name' : 'Simon Holmes'}) .where('age').gt(18) .sort('-lastLogin') .select('_id name email') .exec(function (err, users){ if (!err){ console.log(users); // output array of users found } });

上面代码中的第一行创建了一个queryBuilder.通过使用这个queryBuilder,我们就可以执行一些比较复杂的查找工作,在创建完成这个queryBuilder之后,查询操作并没有马上执行,而是待到执行exec方法时才会去执行数据库的查找。

当然也有另外一种方式能够直接查找数据库的,就是直接在查找方法中添加回调函数,使用方式为:

Model.find(conditions, [fields], [options], [callback])

下面举一个简单例子:

User.find({'name', 'simon holmes'}, function(err, user) {});

另一个稍微复杂的例子:

User.find({'name', 'simon holmes'}, 'name email',function(err, user) { //console.log('some thing'); });

另一个更加复杂的例子,包含查询结果的排序:

User.find({'name' : 'Simon Holmes'}, null, // 如果使用null,则会返回所有的字段值 {sort : {lastLogin : -1}}, // 降序排序 function (err, users){ if (!err){console.log(users);} });

列举几个比较实用的查找方法:

Model.find(query); Model.findOne(query);//返回查找到的所有实例的第一个 Model.findById(ObjectID);//根据ObjectId查找到唯一实例

例如:

User.findOne({'email' : req.body.Email}, '_id name email', function(err, user) { //todo });

2.更新数据

有三种方式来更新数据:

(1)update(conditions,update,options,callback);

该方法会匹配到所查找的内容进行更新,不会返回数据;

(2)findOneAndUpdate(conditions,update,options,callback);

该方法会根据查找去更新数据库,另外也会返回查找到的并未改变的数据;

(3)findByIdAndUpdate(conditions,update,options,callback);

该方法跟上面的findOneAndUpdate方法功能一样,不过他是根据ID来查找文档并更新的。

三个方法都包含四个参数,一下稍微说明一下几个参数的意思:

conditions:查询条件

update:更新的数据对象,是一个包含键值对的对象

options:是一个声明操作类型的选项,这个参数在下面再详细介绍

callback:回调函数

对于options参数,在update方法中和findOneAndUpdate、findByIdAndUpdate两个方法中的可选设置是不同的;

//在update方法中,options的可选设置为: { safe:true|false, //声明是否返回错误信息,默认true upsert:false|true, //声明如果查询不到需要更新的数据项,是否需要新插入一条记录,默认false multi:false|true, //声明是否可以同时更新多条记录,默认false strict:true|false //声明更新的数据中是否可以包含在schema定义之外的字段数据,默认true } //对于findOneAndUpdate、findByIdAndUpdate这两个方法,他们的options可选设置项为: { new:true|false, //声明返回的数据时更新后的该是更新前的,如果为true则返回更新后的,默认true upsert:false|trure, sort:javascriptObject, //如果查询返回多个文档记录,则可以进行排序,在这里是根据传入的javascript object对象进行排序 select:String //这里声明要返回的字段,值是一个字符串 }

下面举个例子:

User.update({_id:user._id},{$set: {lastLogin: Date.now()}},function(){});

3.数据删除

跟更新数据一样,也有三种方法给我们删除数据:

remove(); findOneAndRemove(); findByIdAndRemove();

remove方法有两种使用方式,一种是用在模型上,另一种是用在模型实例上,例如:

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwdyxs.html