mongoose使用简记
mongodb中集合相当于表,常用指令
mongo 进入数据库
use yourdatabase 来选择你的数据集,这个跟关系型中的一样
show collections 来查看你数据集中的表,collection就是关系型中的表
db.createCollection(name,option) name是表名,option(可选)指定有关内存大小和索引选项
db.yourcollection.find() 来查找信息,()里面是查询参数,不填则返回表中全部信息。可以填一个或多个字段,比如{username:"admin“}
db.yourcollection.remove()删除一条或多条信息,但保留表db.yourcollection.drop()删除整个表
db.yourcollection.insert(item)item就是你要插入的数据
db.yourcollection.update(query,updatedata)query就是跟find一样,先找到你要更新的地方,updatedata可以是下面这样
$set:{'title':'New MongoDB Tutorial'}}MongoDB默认将只更新单一的文件,来更新多个你需要设置参数置'multi' 为true {multi:true}
mongodb一个比较好的学习网站 http://www.yiibai.com/mongodb/
mongoose其实就是mongodb的一个封装库。记录一下mongoose的简单使用。
连接:
var mongoose = require('mongoose');
mongoose.connect('mongodb://localhost/test');其中test是你database的名字
创建Schema,就是相当于创建表的结构,跟关系型的一样
var UserSchema = mongoose.Schema({
name: String
})
然后将Schema变成模型(Model),这样你就可以操作Model对象了
var UserInfo = mongoose.model('UserInfo', UserSchema)
这个过程会在数据库中建表,表名就是model方法中的第一个参数+s,比如这个就是userinfos(表名不区分大小写)
添加一条新数据:
var newUser = new UserInfo({ name: 'fluffy' });
newUser.save(function (err, user) {
if (err) return console.error(err);
});
这里匿名函数的第二个参数是插入成功后返回的对象本身
查找:
UserInfo.find({username:username},function (err, user) {
if (err) return callback(err) ;
callback(null,user) ;
});
和mongodb的基本一致需要查找的参数,返回的是对象数组,就算你知道数据库中只有一个对象,也是返回长度为1的数组,如果要只返回一个对象利用findOne方法。
在做应用的时候很有可能有这样的需求就是,我得到了一份用户的名单,我希望传入名单数组得到所对应的这群用户的信息,说白了就是查询条件是一个字段的数组。那么方法如下:
UserInfo.find().where('username').in(arr).exec(function(err,UserList){
if(err){
callback(err) ;
}else {
callback(null,UserList) ;
}
});
其中where中填写的就是字段,in(arr)中的arr就是那个用户名数组
更新:
UserInfo.update({username: data.username}, {$set: {username:“admin”}}, function (err, result) {
callback(result);
});
很有可能遇到Number的字段,然后你想让它在原有的基础上加1或者减1,下面是个减1的例子
UserInfo.update({username: data.username}, {$inc: {follower_count:-1}}, function (err, result) {
console.log("updateFollower" + result);
callback(result);
});
计数:
UserInfo.count(data, function(err,count){
callback(count) ;
});
删除和查找差不多,就不说了,mongoose的文档网站 http://www.nodeclass.com/api/mongoose.html
还有就是我作为萌新遇到的问题:这些操作都是异步的!异步这个思想在node中很重要,所以你一定要在回调函数里对数据进行处理。
mongoose使用简记的更多相关文章
- RangePartitioner 实现简记
摘要: 1.背景 2.rangeBounds 上边界数组源码走读 3.RangePartitioner的sketch 源码走读 4.determineBounds 源码走读 5.关于RangePart ...
- mongoose - 让node.js高效操作mongodb
Mongoose库简而言之就是在node环境中操作MongoDB数据库的一种便捷的封装,一种对象模型工具,类似ORM,Mongoose将数据库中的数据转换为JavaScript对象以供你在应用中使用. ...
- 在mongoose中使用$match对id失效的解决方法
Topic.aggregate( //{$match:{_id:"5576b59e192868d01f75486c"}}, //not work //{$match:{title: ...
- Mongo基础使用,以及在Express项目中使用Mongoose
MongoDB的基本使用 MongoDB特点: 使用BSON存储数据 支持相对丰富的查询操作(相对其他nosql数据库) 支持索引 副本集(支持多个实例/多个服务器运行同个数据库) 分片(数据库水平扩 ...
- mongoose数据库连接和操作
var mongoose = require('mongoose') mongoose.connect('mongodb://localhost:27017/hometown'); var db = ...
- mongoose 和 mongoDB
第三方学习地址:http://blog.csdn.net/foruok/article/details/47746057 下载mongoDB https://www.mongodb.com/downl ...
- Nodejs之MEAN栈开发(三)---- 使用Mongoose创建模型及API
继续开扒我们的MEAN栈开发之路,前面两节我们学习了Express.Jade引擎并创建了几个静态页面,最后通过Heroku部署了应用. Nodejs之MEAN栈开发(一)---- 路由与控制器 Nod ...
- Mongoose Schemas定义中timestamps选项的妙用
在Node.js中使用MongoDB少不了Mongoose. 假设有如下Mongoose Schemas的定义: var ItemSchema = new mongoose.Schema({ biz: ...
- Mongodb 数据类型及Mongoose常用CURD
前言 看完了Node.js实战,其中在数据存储部分提到了Redis.Mongodb,我自己也根据书中的介绍写了几个简单的demo,在demo的过程首先遇到的问题就是数据类型和常见的CURD写法. mo ...
随机推荐
- (双人项目)四则运算 组员:杨钰宁 闫浩楠 开发语言:Python。
需求分析:1.适用人群:小学生. 2.能进行“+,—,*,/” 的四则运算.难度可以随时修改. 3.提交试卷后可以显示所得分数并显示错题个数. 4.可以显示答对的题及其打错的题的序号. 代码如下: i ...
- 操纵Excel文件的 ExcelUtil 类 !
package FileDemo1; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStr ...
- 对ViewModel自定义约束
有时候我们常要对一些属性进行自定义的约束,可以这么做 using ListSys.Entity; using System; using System.Collections; using Syste ...
- 第136天:Web前端面试题总结(理论)
Web前端面试题总结 HTML+CSS理论知识 1.讲讲输入完网址按下回车,到看到网页这个过程中发生了什么 a. 域名解析 b. 发起TCP的3次握手 c. 建立TCP连接后发起http请求 d. 服 ...
- shell脚本学习—正则表达式
正则表达式概念.特点 正则表达式是对字符串操作的一种逻辑公式,就是用事先定义好的一些特定字符.及这些特定字符的组合,组成一个“规则字符串”, 这个“规则字符串”用来表达对字符串的一种过滤辑. 给定一个 ...
- Quartz-作业调度框架
简介 Quartz 是个开源的作业调度框架,为在 Java 应用程序中进行作业调度提供了简单却强大的机制.Quartz 允许开发人员根据时间间隔(或天)来调度作业.它实现了作业和触发器的多对多关系,还 ...
- python基础----函数的定义和调用、return语句、变量作用域、传参、函数嵌套、函数对象、闭包、递归函数
1.函数的定义: 函数是组织好的,可重复使用的,用来实现单一,或相关联功能的代码段. 函数能提高应用的模块性,和代码的重复利用率.你已经知道Python提供了许多内建函数,比如print().但你也可 ...
- windows下安装pthreads扩展注意问题
1.php版本必须是ts版本 2.pthreads扩展下载地址 http://windows.php.net/downloads/pecl/releases/pthreads/ 3.把下载的扩展php ...
- TC规则
633人阅读 TC规则涉及到 队列(QUEUE) 分类器(CLASS) 过滤器(FILTER),filter划分的标志位可用U32或iptables的set-mark来实现 ) 一般是" ...
- valgrind检查C/C++内存泄漏
valgrind --tool=memcheck --leak-check=full ./httptest valgrind --tool=memcheck --leak-check=full -- ...