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 ...
随机推荐
- bash 基础
bash是一些基本的命令组成,要想学好bash脚本,基本命令是必须要记住 红色标记为着重点 1执行命令,利用状态返回值来判断 0 : 成功 1-255:失败 2: 测试表达式 [ expressio ...
- keepalived 高可用(IP飘移)
什么是keepalived? keepalived是一个在c中编写的路由软件,该项目的主要目标是为Linux系统和基于Linux的基础架构提供简单和强大的设备,用于loadbalance和高可用性.l ...
- BOM对象属性定时器的调用
使count中的内容,自动切换 <body> <h1 id="count"></h1> </body> //获取count var ...
- Cobbler环境搭建
Cobbler服务器系统: CentOS 6.6 64位Cobbler版本: cobbler-2.6.11IP地址:192.168.166.136 1.安装epel库 rpm -ivh http:// ...
- break,continue,return 的区别
(1)break 跳出当前循环体 (2)continue 跳过当前循环体continue后面的代码,继续执行下一个循环 (3)return 和循环没关系,就是跳出该函数
- js & right click menu & 鼠标滑词
js & right click menu & 鼠标滑词 // 鼠标滑词 mouseSlipGetWords() { const getSelectionText = () => ...
- MATLAB串口操作和GUI编程
程序说明 V1.0 2015/2/08 MATLAB串口操作和GUI编程 概述 本文介绍了程序AD9512_Serial_GUI的编程思路和功能.该程序设计到MATLAB的图像用户界面编程的基 ...
- asp.net 中使用 pagedlist 分页并具有查询功能的实现方法
用pagedlist在项目中做分页已N次了,今天再次用实例来实现一个带查询功能的分页例子. 1.在view代码: @using PagedList.Mvc@model BGZS.Models.User ...
- 【EF】EF框架 Code First Fluent API
在Code First方法中,还可以通过Fluent API的方式来处理实体与数据表之间的映射关系. 要使用Fluent API必须在构造自定义的DbContext时,重写OnModelCreatin ...
- Docker学习笔记六:Docker搭建企业级私有仓库
前言 Docker不仅是一个强大的服务器部署工具,而且它还有一个官方的Docker Hub registry用于储存Docker镜像.上传镜像到Docker Hub是免费的,上传的镜像文件同时也对公共 ...