Nodejs学习笔记(二)--- 操作MongoDB数据库
最近看了一些关于mongodb的文章,然后就想知道nodeJS是怎么连接的所以我就尝试去了解了一波(这个菜鸟驿站这个网站还不错,虽然知识文档不是最新的,但是还是蛮好的;
顺便官网地址是这个哦:http://mongoosejs.com/docs/guide.html
好了,让我们来进入今天的主题:
首先来进入你项目的根目录下安装: npm install mongoose
关于mongoose, 有三个概念:Schema、Model 和 Entity
Schema: 一种以文件形式存储的数据库模型框架,不具备操作数据库的能力。
{ 每个Schema会映射到MongoDB中的一个给定的集合(Collection)}
Model: 由Schema发布的模型,具有抽象的属性和行为,可以直接操作数据库。
{ 在mongoose中,所有的数据都是一种模型(Model),每个模型都映射到MOngDB的一个集合,并且定义了该集合文件结构}
Entity: 由Model创建的实体,它可以直接操作数据库。
一直想用下这个数据的,最近终于得偿所愿。数据库的使用,我觉得首先是从增删改查开始,然后才去像更加复杂的地步去卖家
首先如何去获取他的连接
创建db.js , 可以直接通过node db.js 命名去观察连接的效果
一 建立连接
var mongoose = require('mongoose'),
DB_URL = 'mongodb://127.0.0.1:27017/Test';
// 连接
mongoose.connect(DB_URL);
// 测试连接是否成功
mongoose.connection.on('connected', function () {
console.log('my mongodb connection success !!!')
})
// 连接异常的情况
mongoose.connection.on('error', function (er) {
console.log('connection error: ' + er);
})
// 连接断开
mongoose.connection.on('disconnected', function () {
console.log('mongogdb disconnection')
})
module.exports = mongoose;
二: 创建数据模型
创建Schema ( 有点类似创建实例属性) 并建立Model
// 获取连接
var mongoose = require('./db.js'),
Schema = mongoose.Schema; // 创建用户
var userInfo = new Schema({
uid: {type: String},
uname: {type: String},
upwd: {type: String},
loginDate: {type: Date}
}) // 将定义好的schema 转换为model
module.exports = mongoose.model('userInfo', userInfo);
三 对数据库操作
3.1 插入操作:
var User = require('./userInfo.js')
/*
插入操作
*/
function insert() {
var userInfo = new User({
uid: '',
uname: 'yaobo1',
upwd: '',
loginDate: new Date()
})
userInfo.save(function (err, res) {
if(err) {
console.log('err' + err);
} else {
console.log('res:' + res)
}
})
// 插入多条
userInfo.insertMany([], function (err, res) {
})
} insert();
3.2 查询操作:
这里在做模糊查询的时候是使用正则表达式来判断的
- i 忽略大小写,{<field>{$regex/pattern/i}},设置i选项后,模式中的字母会进行大小写不敏感匹配。
- m 多行匹配模式,{<field>{$regex/pattern/,$options:'m'},m选项会更改^和$元字符的默认行为,分别使用与行的开头和结尾匹配,而不是与输入字符串的开头和结尾匹配。
- x 忽略非转义的空白字符,{<field>:{$regex:/pattern/,$options:'m'},设置x选项后,正则表达式中的非转义的空白字符将被忽略,同时井号(#)被解释为注释的开头注,只能显式位于option选项中。
- s 单行匹配模式{<field>:{$regex:/pattern/,$options:'s'},设置s选项后,会改变模式中的点号(.)元字符的默认行为,它会匹配所有字符,包括换行符(\n),只能显式位于option选项中。
- i,m,x,s可以组合使用,例如:{name:{$regex:/j*k/,$options:"si"}}
- 在设置索弓}的字段上进行正则匹配可以提高查询速度,而且当正则表达式使用的是前缀表达式时,查询速度会进一步提高,例如:{name:{$regex: /^joe/}
var User = require('./userInfo.js')
/*
查询操作
*/
function find() {
let wherestr = {uid: '1'}
User.find(wherestr, function (err, res) {
if(err) {
console.log('err' + err);
} else {
console.log('res:' + res)
}
})
}
/*
模糊查询
*/
function getRegex(){
var wherestr = {uname: {$regex: /yaobo/m}}
console.log(wherestr);
User.find(wherestr, function (err, res) {
if(err) {
console.log('err' + err);
} else {
console.log('res:' + res)
}
})
}
/*
聚合查询
*/
function aggregate(){
var wherestr = [{$group: {_id: '$uname', num: {$sum: 1}}}]
console.log(wherestr);
User.aggregate(wherestr, function (err, res) {
if(err) {
console.log('err' + err);
} else {
console.log('res:' + JSON.stringify(res))
}
})
}
//find();
// http://blog.csdn.net/u022812849/article/details/51314810
// getRegex();
aggregate();
3.3 删除操作
var User = require('./userInfo.js')
function remove() {
let wherestr = {uid: '1'}
User.remove(wherestr, function (er, res) {
if (er) {
console.log('er:', er)
}
if (res) {
console.log('res', res)
}
})
}
remove();
3.4 更新操作
var User = require('./userInfo.js')
function update() {
var wherestr = {uname: 'yaobo1'}
var updatestr = {uname: '神奇的造物主'}
User.update(wherestr, updatestr, function (er , res) {
if (er) {
console.log('er:', er)
}
if (res) {
console.log('res', res)
}
})
}
update();
其实这样写下来就会发现,掌握了结构之后,就是知道如何去使用nodejs去操作mongodb, 可能有些复杂的没写(后续有好的东西,再往上加),不过基本语句掌握了,掌握mongdb的语言就尤为重要了
Nodejs学习笔记(二)--- 操作MongoDB数据库的更多相关文章
- nodejs学习笔记二——链接mongodb
a.安装mongoose库用来链接mongodb数据库 安装mongodb数据库参考mongodb安装 前言(怨言) 本来是想安装mongodb库来链接mongodb的,命令行到nodejs工程目录: ...
- MongoDB学习笔记:Python 操作MongoDB
MongoDB学习笔记:Python 操作MongoDB Pymongo 安装 安装pymongopip install pymongoPyMongo是驱动程序,使python程序能够使用Mong ...
- Javascript学习笔记二——操作DOM
Javascript学习笔记 DOM操作: 一.GetElementById() ID在HTML是唯一的,getElementById()可以定位唯一的一个DOM节点 二.querySelector( ...
- 【MongoDB学习之二】MongoDB数据库、文档、集合、元数据
环境 MongoDB 4.0 CentOS6.5_x64 一.连接语法格式: mongodb://[username:password@]host1[:port1][,host2[:port2],.. ...
- C#学习笔记---C#操作SQL数据库
C#操作SQL数据库 Connection(连接)对象 连接字符串: 形式1.”server=;uid=;pwd=;database=” 形式2.”server=;Intergrated Securi ...
- python学习笔记之——操作mysql数据库
Python 标准数据库接口为 Python DB-API,Python DB-API为开发人员提供了数据库应用编程接口. Python 数据库接口支持非常多的数据库,你可以选择适合你项目的数据库: ...
- Redis学习笔记二:单机数据库的实现
1. 数据库 服务器中的数据库 Redis服务器将所有数据库都保存在服务器状态redis.h/redisServer结构的db数组中,db数组的每个项都是一个redis.h/redisDb结构,每个r ...
- nodejs学习笔记二:解析express框架项目文件
上一章介绍了如何去创建一个express框架的工程项目,这章介绍一下express框架下的文件和用法解析,上一张我们创建的工程项目结构图如下: models是不属于原工程项目结构,为了实现数据模型后添 ...
- nodejs学习笔记<二>简单的node服务器
在环境搭建好后,就可以开始动手架设(node驱动)一个简单的web服务器. 首先,nodejs还是用js编写.先来看一段node官网上的实例代码. var http = require('http') ...
- nodejs学习笔记<二> 使用node创建基础服务器
创建服务器的 server.js 内容. var http = require("http"); // 引用http模块 http.createServer(function(re ...
随机推荐
- 如何使用yii2的缓存依赖特性
目录 如何使用yii2的缓存依赖特性 概述 页面缓存 缓存依赖 链式依赖 总结 如何使用yii2的缓存依赖特性 概述 缓存是Yii2的强大特性之一,合理使用缓存技术可以有效地减小服务器的访问压力.Yi ...
- python 将歌词解析封装成类,要求:提供一个方法(根据时间返回歌词) - 提示:封装两个类:歌词类、歌词管理类
自己写的 有更好方案的大佬可以讨论一下 import bisectclass Lrc(): def __init__(self, sec, lrc): self.sec = sec self.lrc ...
- 音频算法之小黄人变声 附完整C代码
前面提及到<大话音频变声原理 附简单示例代码>与<声音变调算法PitchShift(模拟汤姆猫) 附完整C++算法实现代码> 都稍微讲过变声的原理和具体实现. 大家都知道,算法 ...
- 获取http-post请求的原生报文
BufferedReader br = new BufferedReader(new InputStreamReader(request.getInputStream(), "utf-8&q ...
- NIH周三讲座视频爬虫
最近网是越来越差了,在线播放基本是没戏了,所以就动了爬虫下载的念头. NIH把视频片段存放,一般都是8秒一段,大概看下视频长度估算一下片段个数就差不多了. 新建一个NIH的文件夹,然后把爬虫下来的.t ...
- 20155203 2016-2017-2《Java程序设计》课程总结
目录 一.每周作业链接汇总 自认为写得最好一篇博客是?为什么? 作业中阅读量最高的一篇博客是?谈谈经验 作业中与师生交互最多的一篇博客是?谈谈收获 二.实验报告链接汇总 三.代码托管链接 四.课堂项目 ...
- 20155230 《Java程序设计》实验五 Java网络编程及安全
20155230 <Java程序设计>实验五 Java网络编程及安全 实验内容 1.掌握Socket程序的编写: 2.掌握密码技术的使用: 3.设计安全传输系统. 实验1 两人一组结对编程 ...
- [CTSC1997]选课
题面 题解 树形背包板子题. 设\(f[i][j]\)表示在以\(x\)为根的子树选\(j\)门课(包括\(x\))能够获得的最高学分,用分组背包转移即可. 代码 #include<cstdio ...
- 实时备份工具之inotify+rsync
1.inotify简介 inotify 是一个从 2.6.13 内核开始,对 Linux 文件系统进行高效率.细粒度.异步地监控机制, 用于通知用户空间程序的文件系统变化.可利用它对用户空间进行安全. ...
- cogs1439 货车运输
cogs1439 货车运输 一道傻逼板子题. 边一定在最大生成树上,这个可以用消圈证明 然后kruskal跑一遍再搜一遍再建ST表再跑LCA这题就做完了. RT PS.交上去的代码把Kruskal打成 ...