Moogoose操作之Schema实现增删查改
Schema不仅定义了文档结构和使用性能,可以为后面的Model和Entity提供公共的属性和方法。
Schema、Model、Entity的关系:
Schema : 可以定义字段类型,不具备数据库的操作能力
Model : 由Schema发布生成的模型,具有抽象属性和行为的数据库操作对
Entity : 由Model创建的实体,他的操作也会影响数据库
Schema生成Model,Model创造Entity,Model和Entity都可对数据库操作造成影响,但Model比Entity更具操作性
基本使用:
/*****数据库连接*****/
//引入mongoose模块
var mongoose = require('mongoose');
//创建数据库连接
mongoose.connect('mongodb://localhost/test'); /*****Schema使用*****/ //定义kitty属性
var kittySchema = mongoose.Schema({
name: String
});
//将该Schema发布为Model,第一个参数为集合名
var kittyModel = mongoose.model('kitty', kittySchema); //用module创建kitty实体
var kittyEntity = new kittyModel({ name: 'tinyphp' });
console.log(kittyEntity.name); //打印实体名字 /************/
还可以为添加方法,看红色部分:
/*****Schema使用*****/ //定义kitty属性
var kittySchema = mongoose.Schema({
name: String
});
//为Schema创建方法
kittySchema.methods.speak=function(){
console.log('我的名字叫'+this.name);
}
//将该Schema发布为Model,第一个参数为集合名
var kittyModel = mongoose.model('kitty', kittySchema); //用module创建kitty实体
var kittyEntity = new kittyModel({ name: 'tinyphp' });
//console.log(kittyEntity.name); //打印实体名字
kittyEntity.speak();
/************/

添加以下可以保存数据到数据库
//执行完成后,数据库就有该数据了
kittyEntity.save();

需要注意的是,集合的名字会变成复数,如上:kitty->kitties
下面将分别实现插入、查询、删除、修改,建议先插入多条数据,以便测试噢~
module.js
/*****数据库连接*****/
//引入mongoose模块
var mongoose = require('mongoose');
//创建数据库连接
mongoose.connect('mongodb://localhost/test'); /*****Schema使用*****/ //定义kitty属性
var kittySchema = mongoose.Schema({
name: String
}); //将该Schema发布为Model,第一个参数为集合名
mongoose.model('kitty', kittySchema);
插入 insert.js
var mongoose = require('mongoose');
require('./module.js');
//不传Schema时,返回kitty 的model,而此model在module已经发布了
var kittyModel = mongoose.model('kitty');
//创建实体
var kittyEntity = new kittyModel({ name: 'Mei' });
//保存数据
kittyEntity.save(function(err){
console.log('save status:',err? 'fail':'success');
});
查询所有 find.js
var mongoose = require('mongoose');
require('./module.js');
var kittyModel = mongoose.model('kitty');
//查询
kittyModel.find({},function(err,docs){
if(err){
console.log('err:',err);
return;
}
console.log('result:',docs);
});
模糊查询参考
var name='x';
.......find({name: new RegExp("^.*"+name+".*$")} ...........
多条件查询 condition.js
var mongoose = require('mongoose');
require('./module.js');
var kittyModel = mongoose.model('kitty');
//多条件查询$or、$and等
var cond = {
$or:[
{name:'Mei2'}
]
}
kittyModel.find(cond,function(err,doc){
if(err){
console.log('find by cond err:',err);
return;
}
console.log('cond:',cond,'result:',doc);
});
查询某条记录findOne.js
var mongoose = require('mongoose');
require('./module.js');
var kittyModel = mongoose.model('kitty');
//查询一条
kittyModel.findOne({"name":"Mei"},function(err,doc){
if(err){
console.log('err:',err);return;
}
console.log('findOne result:',doc);
});
删除 remove.js
var mongoose = require('mongoose');
require('./module.js');
var kittyModel = mongoose.model('kitty');
//先找出来然后删除
kittyModel.findOne({"name":"Mei"},function(err,doc){
if(err){
console.log('err:',err);
return;
}
if(doc){
doc.remove();
console.log('删除了');
}
});
删除多条:
var mongoose = require('mongoose');
require('./module.js');
var kittyModel = mongoose.model('kitty');
//先找出来然后删除
kittyModel.find({"name":"tinyphp"},function(err,docs){
if(err){
console.log('err:',err);
return;
}
for(var i=0;i<docs.length;i++){
docs[i].remove();
console.log('deleteId:'+i);
}
});
修改updateOne.js
var mongoose = require('mongoose');
require('./module.js');
var kittyModel = mongoose.model('kitty');
//修改一条
kittyModel.findOne({"name":"Tom"},function(err,doc){
if(err){
console.log('err:',err);
return;
}
doc.name='tinyphp';
doc.save();
console.log('update result:',doc);
});
分别执行node insert.js ....等就可以看到效果了,图片好占位置,自己对比就好,最最值得注意的是先打开mongoDB的服务,不然也是徒劳。
全部实例下载:
Moogoose操作之Schema实现增删查改的更多相关文章
- go语言操作mysql范例(增删查改)
http://blog.csdn.net/jesseyoung/article/details/40398321 go语言连接mysql简介 go官方仅提供了database package,d ...
- java代码操作solr搜索引擎的增删查改
所需的包如图: 代码如下:package solr; import java.util.List;import java.util.Map; import org.apache.solr.client ...
- SSH2 增删查改实例
(一)引入包 (共73个,不一定都需要,但是我的项目是这么多,经过调试,没有包冲突) (二)创建数据库表 建立数据库octtest,并创建user表,表里面一共4个字段:id,姓,名,年龄. 语句如下 ...
- [置顶] cocos2dx sqllite 增删查改等操作
首先导入文件shell.c sqllite3.c sqlite3.h sqlite3etx.h文件(注意在生成安卓项目是 不要将shell.c写进android.mk文件中,写进去在cywin中生成会 ...
- 利用dbutils工具实现数据的增删查改操作(dbutis入门)
一.前期准备 1.安装数据库(如:mysql5.5) 2.安装Eclipse(如:3.4) 3.下载数据库驱动包 4.下载dbutis工具包 5.在Eclipse创建名为 dbutils 的工程并在工 ...
- SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)
SQL Server 表的管理_关于数据增删查改的操作的详解(案例代码)-DML 1.SQL INSERT INTO 语句(在表中插入) INSERT INTO 语句用于向表中插入新记录. SQL I ...
- SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码)
SQL Server 表的管理_关于表的操作增删查改的操作的详解(案例代码) 概述: 表由行和列组成,每个表都必须有个表名. SQL CREATE TABLE 语法 CREATE TABLE tabl ...
- PHP与MYSQL结合操作——文章发布系统小项目(实现基本增删查改操作)
php和mysql在一起几十年了,也是一对老夫老妻了,最近正在对他们的爱情故事进行探讨,并做了一个很简单的小东西——文章发布系统,目的是为了实现mysql对文章的基本增删查改操作 前台展示系统有:文章 ...
- Mybatis基础配置及增删查改操作
一.简介 平时我们都用JDBC访问数据库,除了需要自己写SQL之外,还必须操作Connection, Statement, ResultSet 这些其实只是手段的辅助类. 不仅如此,访问不同的表,还会 ...
随机推荐
- ZOJ 3908 Number Game ZOJ Monthly, October 2015 - F
Number Game Time Limit: 2 Seconds Memory Limit: 65536 KB The bored Bob is playing a number game ...
- ios CGImageRelease 出现 EXC_BAD_ACCESS的错误 ios特定形状剪裁图片 内存泄露
CGImageRef imgRef = [image CGImage]; 通过此种方式的得到的CGImageRef不能利用CGImageRelease释放,因为你不拥有它所以不用释放 在ios中特定形 ...
- 【wikioi】2800 送外卖(状压dp+floyd)
http://www.wikioi.com/problem/2800/ 本题状压莫名其妙的tle了,(按照hzwer大神打的喂,他1000多ms,我就2000ms了?) (14.8.7更,将getnu ...
- Redis内存存储结构分析
1 Redis 内存存储结构 本文是基于 Redis-v2.2.4 版本进行分析. 1.1 Redis 内存存储总体结构 Redis 是支持多key-value数据库(表)的,并用 RedisDb 来 ...
- 让IE下支持Html5的placeholder属性
HTML5对Web Form做了许多增强,比如input新增的type类型.Form Validation等. Placeholder 是HTML5新增的另一个属性,当input或者textarea设 ...
- Function Scope
JavaScript’s function scope means that all variables declared within a function are visi-ble through ...
- 关于isset使用产生Can't use function return value in write context错误
在使用isset检测session的一个取值是否存在时,产生了这个问题 翻译一下:不能在填写的内容中使用函数的返回值.然后我查看了php手册看isset函数的使用:isset()只能用于变量,因为传递 ...
- Html - 涟漪特效
这种效果稍加改造非常优雅.并且可以准确的实验触摸聚焦点.缺点是非常消耗内存.娱乐为主吧 js //╠═╬═╬═╬═╬═╬═╬═╬═╬═╬═╣ 涟漪特效 ╠═╬═╬═╬═╬═╬═╬═╬═╬═╬═╣ 涟漪 ...
- 上传文件及$_FILES的用法实例
Session变量($_SESSION):�php的SESSION函数产生的数据,都以超全局变量的方式,存放在$_SESSION变量中.1.Session简介SESSION也称为会话期,其是存储在服务 ...
- linux redis迁移
在原服务器上的redis执行save命令后,生成了dump文件,拷贝到新服务器的安装目录,可能是版本问题,数据无法还原. 针对这个问题, 1.在配置文件中加入: slave of 原服务器的ip和端口 ...