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 这些其实只是手段的辅助类. 不仅如此,访问不同的表,还会 ...
随机推荐
- 模拟 2013年山东省赛 J Contest Print Server
题目传送门 /* 题意:每支队伍需求打印机打印n张纸,当打印纸数累计到s时,打印机崩溃,打印出当前打印的纸数,s更新为(s*x+y)%mod 累计数清空为0,重新累计 模拟简单题:关键看懂题意 注意: ...
- POJ1191 棋盘分割(DP)
化简一下那个方差得到:$$\sqrt\frac{(\Sigma_{i=1}^nx_i)-n\bar x^2}{n}$$ 除了$\Sigma_{i=1}^nx_i$这部分未知,其余已知,而那部分显然越大 ...
- UVa10917 A Walk Through the Forest(SPFA+记忆化搜索)
题目给一张有向图,问从起点1到终点2沿着合法的路走有种走法,合法的路指从u到v的路,v到终点的距离严格小于u到终点的距离. 先SPFA预处理出所有合法的路,然后这些路肯定形成一个DAG,然后DP一下就 ...
- 学习C# XmlSerializer 序列化反序列化XML
类.变量常用头: [XmlRootAttribute]:对根节点的描述,在类声明中使用 如:下例的Html类 [XmlType]:对节点描述,在类声明中使用 如:下例的Head类 [X ...
- NOIp 2006 作业调度方案 Label:坑 模拟(tyvj你不给我ac,我就把名字献给附中oj)
福建师大附中链接:http://218.5.5.242:9018/JudgeOnline/problem.php?id=1211 [问题描述] 我们现在要利用m台机器加工n个工件,每个工件都有m道工序 ...
- 我的conky配置
安装conky的方法请看我博客另外一篇文章,这里不再阐述点这里 附上我的配置2013.08.29(吾喷) background no font WenQuanYi Micro Hei:size=10 ...
- Graph database_neo4j 底层存储结构分析(3)
3.3 通用的Store 类型 3.3.1 id 类型 下面是 neo4j db 中,每种Store都有自己的ID文件(即后缀.id 文件),它们的格式都是一样的. [test00]$ls - ...
- C#中使用JQueryUI中Autocomplete插件
服务器端后台代码: 1 private string GetModelNames() { 2 return @"[ 3 { 4 'value': 'jquery', 5 'label': ' ...
- stringstream 使用方法
C++中的stringstream是专门用来处理字符串流的,可以按顺序将string或int都拼接起来,而不用把int转换为string格式,使用方法如下: #include <string&g ...
- 转载:hdu 动态规划题集
1.Robberies 连接 :http://acm.hdu.edu.cn/showproblem.php?pid=2955 背包;第一次做的时候把概率当做背包(放大100000倍化为整数): ...