从零开始优雅的使用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 ...
随机推荐
- mysql语句判断是否存在记录,没有则插入新纪录否则不执行
1 前言 由于项目需要,当某个表如果有记录,就不执行加入语句,否则加入新纪录(测试数据).思路是:判断表的记录是否为空,然后再决定是否插入 2 代码 DROP PROCEDURE IF EXISTS ...
- jQuery版本的jsonp
1.一个众所周知的问题,Ajax直接请求普通文件存在跨域无权限访问的问题,甭管你是静态页面.动态网页.web服务.WCF,只要是跨域请求,一律不准: 2.不过我们又发现,Web页面上调用js文件时则不 ...
- C#面向对象(继承)
- 保存 laravel model 而不更新 timestamps 的方法
$product = Product::find(1); $product->view_count += 1; $product->timestamps = false; $product ...
- Slave SQL_THREAD如何重放Relay log
复制的介绍: 根据日志定义的模式不一样,可以分为:Statement(SBR)模式,Row(RBR)格式或者是MIXED格式,记录最小的单位是一个Event,binlog日志前4个字节是一个magic ...
- Thread + 匿名内部类
package chapter01; public class MyThread01 extends Thread{ @Override public void run() { //让当前线程执行的代 ...
- 【C++ Primer | 15】C++类内存分布
C++类内存分布 书上类继承相关章节到这里就结束了,这里不妨说下C++内存分布结构,我们来看看编译器是怎么处理类成员内存分布的,特别是在继承.虚函数存在的情况下. 下面可以定义一个类,像下面这样: c ...
- POJ 3280 Cheapest Palindrome【DP】
题意:对一个字符串进行插入删除等操作使其变成一个回文串,但是对于每个字符的操作消耗是不同的.求最小消耗. 思路: 我们定义dp [ i ] [ j ] 为区间 i 到 j 变成回文的最小代价.那么对于 ...
- vue2.0组件传值
props down emit up 嘿嘿 如果是第一次接触vue2.0组件传值的肯定很疑惑,这是什么意思(大神总结的,我也就是拿来用用) “down”—>指的是下的意思,即父组件向子 ...
- MySQL 8.0 Docker使用注解
PUBLIC | AUTOMATED BUILD cytopia/mysql-8.0 Last pushed: 8 months ago Repo Info Tags Dockerfile Build ...