从零开始优雅的使用mongodb实例
基本连接
一、创建express工程testmon
express testmon
二、精简app.js
var express = require("express");
var app = express();
app.get('/', function(req, res) {
res.send('访问一次增加一条数据');
}); var server = app.listen(3000,function(){
console.log("请在浏览器访问:http://localhost:3000");
});
三:进入工程目录安装mongoose并引入依赖:
npm install --save mongoose
四、修改app.js
var express = require("express");
var app = express();
app.get('/', function(req, res) {
res.send('Hello, tinyphp');
});
var server = app.listen(3000,function(){
console.log("请在浏览器访问:http://localhost:3000");
}); //引入mongoose模块
var mongoose = require('mongoose');
//创建数据库连接
var db=mongoose.connect('mongodb://localhost:27017/test'); //检查是否连接成功
db.connection.on("error",function(error){
console.log("数据库连接失败:"+error);
}); db.connection.on("open",function(error){
console.log("++++++数据库连成功++++++");
}); /*****Schema使用*****/ //定义kitty属性
var kittySchema = mongoose.Schema({
name: String
});
//将该Schema发布为Model,第一个参数为集合名
var kittyModel = mongoose.model('kitty', kittySchema); //用module创建kitty实体
var kittyEntity = new kittyModel({ name: 'tinyphp99' }); //保存数据
kittyEntity.save(function (err) {
if (err) {
console.log(err);
} else {
console.log('成功插入数据');
}
});
/************/
打开另外一个cmd窗口,先查询一次数据,然后重新启动工程,再查询一次数据发现数据成功添加上了
分离改造
下面我们把它改装为一访问http://localhost:3000/add就自动添加数据,思路
config.js 数据库配置信息
module.exports={
mongodb:"mongodb://localhost:27017/test"
}
mongoose.js 数据库连接文件
//引入mongoose模块
var mongoose = require('mongoose');
var config=require('./config.js'); module.exports=function(){
//创建数据库连接
var db=mongoose.connect(config.mongodb);
//检查是否连接成功
db.connection.on("error",function(error){
console.log("数据库连接失败:"+error);
}); db.connection.on("open",function(error){
console.log("++++++数据库连成功++++++");
});
require('../models/kitty.model.js');
return db;
}
kitty.model.js 导出Model用于生成实体
var mongoose =require('mongoose');
/*****Schema使用*****/ //定义kitty属性
var kittySchema = mongoose.Schema({
name: String
}); mongoose.model('kitty',kittySchema);
app.js
var express = require("express"); var mongoose = require('./config/mongoose.js');
var db=mongoose(); var app = express(); var add=require('./routes/add');
app.use('/add',add); var server = app.listen(3000,function(){
console.log("请在浏览器访问:http://localhost:3000");
});
add.js 控制访问一次http://localhost:3000/add插入一次数据
var express = require('express');
var router = express.Router(); var mongoose =require('mongoose');
//将该Schema发布为Model,第一个参数为集合名
var kittyModel=mongoose.model('kitty'); /* GET home page. */
router.get('/', function(req, res, next) {
res.send('又添加一条数据'); //用module创建kitty实体
var kittyEntity = new kittyModel({ name: 'tom' }); //保存数据
kittyEntity.save(function (err) {
if (err) {
console.log(err);
} else {
console.log('成功插入数据');
}
}); }); module.exports = router;
路由里因为用到kittyModel所以引入要在mongoose初始化后,不然会提示出错“Schema hasn't been registered ...”, 自己把上面的顺序调换测试下更深刻噢~
温馨提示:测试多了,不妨使用db.table.drop() 把整个集合删除掉噢
相关文章:
从零开始优雅的使用mongodb实例的更多相关文章
- 单台MongoDB实例开启Oplog
背景 随着数据的积累,MongoDB中的数据量越来越大,数据分析团队从数据库中抽取变化数据(假如依据栏位createdatetime,transdatetime),越来越困难.我们知道MongoDB的 ...
- MongoDB实例重启失败探究(大事务Redo导致)
1.实例重启背景 收到监控组同学反馈,连接某一个MongoDB实例的应用耗时异常,并且出现了超时.查看数据库监控平台,发现此实例服务器的IO异常飙升,而查看副本集状态(rs.status()),主从是 ...
- asp.net的mongodb实例
mongodb为2.6版本, .net是4.0, c#接口时1.7. 运行环境为windows8 with visual studio2010 注意事项:在mongodb中使用地理位置存储信息且动用到 ...
- 利用golang优雅的实现单实例
平时编写代码过程中,经常会遇到对于全局角度只需运行一次的代码,比如全局初始化操作,设计模式中的单例模式.针对单例模式,java中又出现了饿汉模式.懒汉模式,再配合synchronized同步关键字来实 ...
- PHP 操作Mongodb 实例
缩略版本<?php //1.连接MongoDB $mongo = new Mongo(); $mongo = new Mongo("mongodb://username:passwor ...
- python操作mongodb实例
安装pymongo扩展 import pymongo; client = pymongo.MongoClient(host='10.48.176.170',port=27017); db = clie ...
- 从零开始配置Ubuntu 14.04&SSH&curl&Git&MongoDB&Node.js
从零开始配置Ubuntu 14.04 从零开始配置Ubuntu 14.04,记录配置服务的过程,安装组件如下: SSH curl Git MongoDB Node.js ... Ubuntu 安装 ...
- MongoDB在已有账号的实例下还原数据库报错的分析(error applying oplog)
一. 背景 今天在MongoDB 4.0.4版本下,在还原恢复数据库时报错. 主要错误为: Failed: restore error: error applying oplog: applyOps: ...
- [转]MongoDB更新操作replaceOne()实例讲解
最近正在学习MongoDB,作为数据库的学习当然是要从CRUD开始学起了.这篇文章默认读者是知道如何安装MongoDB.如何运行MongoDB实例以及了解了MongoDB中的collection.do ...
随机推荐
- php中相对路径和绝对路径如何使用(详解)
目录 一.总结 一句话总结: 1.php中用用“/”表示根目录么? 2.什么符号表示当前目录(asp,jsp,php都一样)? 3.php中如何使用$_SERVER['DOCUMENT_ROOT']做 ...
- Javascript之BOM与DOM讲解
一.Javascript组成 JavaScript的实现包括以下3个部分: ECMAScript(核心) 描述了JS的语法和基本对象. 文档对象模型 (DOM) 处理网页内容的方法和接口 浏览器对象模 ...
- ios如何实现静音模式下声音仍然可以外放
AVAudioSession *audioSession = [AVAudioSession sharedInstance]; [audioSession setCategory:AVAudioSes ...
- 最全的基于MFC的ActiveX控件开发教程
浏览器插件之ActiveX开发(一) 一般的Web应用对于浏览器插件能不使用的建议尽量不使用,因为其涉及到安全问题以及影响用户安装(或自动下载注册安装)体验问题.在有特殊需求(如涉及数据安全的金融业务 ...
- PHP实现获取文件后缀名的几种常用方法
方法1: function get_file_type($filename){ $type = substr($filename, strrpos($filename, ".")+ ...
- IntelliJ IDEA 下的SVN使用
最近公司的很多同事开始使用IntelliJ Idea,便尝试了一下,虽然快捷键与eclipse 有些不同,但是强大的搜索功能与“漂亮的界面”(个人认为没有eclipse好看 ),还是值得我们去使用的. ...
- 事件方法on()
on()方法用来处理事件.jQuery会处理所有浏览器的兼容性问题. on()方法可以指定影响哪个事件,相当于JavaScript中的addEventListener()事件监听. on()方法有两个 ...
- openstack学习-Horizon安装(八)
一.安装Horizon [root@linux-node2 ~]# yum install -y openstack-dashboard 二.Horizon配置 [root@linux-node2 ~ ...
- win10下Spark的环境搭建
win10下Spark的环境搭建 2018-08-19 18:36:45 一.jdk 1.8.0 安装与配置 二.scala 2.11.8 安装与配置http://www.scala-lang.or ...
- BZOJ1786 [Ahoi2008]Pair 配对 动态规划 逆序对
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ1786 题意概括 给出长度为n的数列,只会出现1~k这些正整数.现在有些数写成了-1,这些-1可以变 ...