平凡之路

1、创建express项目

express mongooseExpress

2、最简express

var express = require("express");
var app = express();
app.get('/', function(req, res) {
res.send('Hello, tinyphp');
});
,function(){
    console.log("请在浏览器访问:http://localhost:3000");
});

3、进入工程目录安装mongoose并引入依赖:

npm install --save mongoose

4、修改app.js

var express = require("express");
var app = express();
app.get('/', function(req, res) {
res.send('Hello, tinyphp');
});
,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' });
console.log("添加数据"+kittyEntity.name);  //打印实体名字
//保存数据
kittyEntity.save();

/************/

成功插入一条记录

这里可以看见,所有的操作都是在app.js里面实现的,怎么把他们分离出来呢?

想着想着去肯德基不小心跟服务员说:要两串骨肉分离吧...

开始改造

下面我们把它改装为一访问http://localhost:3000/add就自动添加数据,

config.js 数据库配置信息

module.exports={
    mongodb:"mongodb://localhost:27017/test"
}

mongoose.js 数据库连接文件

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');

var kittySchema = mongoose.Schema({
    name: String
});

mongoose.model('kitty', kittySchema);

add.js 使用路由简化启动文件逻辑

var express = require('express');
var router = express.Router();
//引入mongoose
var mongoose =require('mongoose');

var kittyModel = mongoose.model('kitty');

/* GET users listing. */
router.get('/', function(req, res, next) {
    //用module创建kitty实体
var kittyEntity = new kittyModel({ name: 'china' });
    //保存数据
  kittyEntity.save();
  res.send("添加数据:"+kittyEntity.name);  

});

module.exports = router;

app.js

var express = require("express");

//数据库连接
var mongoose =require('./config/mongoose.js');
var db =mongoose();
var add=require('./routes/add');
var app = express();

//使用路由,便于访问add直接添加数据
app.use('/add', add);

,function(){
    console.log("请在浏览器访问:http://localhost:3000");
});

执行node app.js

浏览:http://localhost:3000/add

数据name为China的信息成功添加!

温馨提示:测试多了,不妨使用db.table.drop() 把整个集合删除掉噢

注意事项:

mongoose的初始化,要在 express 之前的,

路由里因为用到kittyModel所以引入要在mongoose初始化后,不然会提示出错“Schema hasn't been registered ...”, 自己把上面的顺序调换测试下更深刻噢~

下载地址

在express项目中有效组织和使用mongoose的更多相关文章

  1. Mongo基础使用,以及在Express项目中使用Mongoose

    MongoDB的基本使用 MongoDB特点: 使用BSON存储数据 支持相对丰富的查询操作(相对其他nosql数据库) 支持索引 副本集(支持多个实例/多个服务器运行同个数据库) 分片(数据库水平扩 ...

  2. 在express项目中使用formidable & multiparty实现文件上传

    安装 formidable,multiparty 模块 npm install formidable,multiparty –save -d 表单上传 <form id="addFor ...

  3. 在express项目中使用redis

    在express项目中使用redis 准备工作 安装redis 安装redis桌面管理工具:Redis Desktop Manager 项目中安装redis:npm install redis 开始使 ...

  4. 【转】在Express项目中使用Handlebars模板引擎

    原文:http://fraserxu.me/2013/09/12/Using-Handlebarsjs-with-Expressjs/ 最近在用Expressjs做一个项目,前后端都用它来完成.自己之 ...

  5. 浅谈 OneAPM 在 express 项目中的实践

    [编者按]OneAPM 运营团队,近日在 github 上发现了一篇文章,特别奉献给大家.本文作者王宇先生从2015年年初就开始使用我们的产品,也是OneAPM 的忠实用户. OneAPM 是一个优秀 ...

  6. Atitit.css 规范 bem  项目中 CSS 的组织和管理

    Atitit.css 规范 bem  项目中 CSS 的组织和管理 1. 什么是BEM?1 1.1. 块(Block)2 1.2. 元素(Element)2 1.3. BEM树(和DOM树类似).3 ...

  7. 基于Node 的http转发demo,项目中请使用express+http-proxy-middleware

    var http = require("http"); var data = ''; function getData() { const options = { host: 'w ...

  8. 项目中使用express,只是单纯项目中使用

    安装express npm install express --save-dv 建议安装到dev依赖里面 安装body-parse npm install body-parser --save-dev ...

  9. Express 项目,res.cookie() 设置 Cookie 无法被保存在浏览器的 Application 中

    res.cookie() 给客户端响应头封装的 Cookie 无法被保存在客户端浏览器的 Application 中,只能在 Set-Cookie 中看到有这个值: 在前后端分离项目中,存在跨域问题, ...

随机推荐

  1. 水题 ZOJ 3880 Demacia of the Ancients

    题目传送门 /* 水题:) */ #include <cstdio> #include <iostream> #include <algorithm> #inclu ...

  2. POJ3321 Apple Tree(DFS序)

    题目,是对一颗树,单点修改.子树查询.典型的dfs序入门题. DFS序可以将一颗树与子树们表示为一个连续的区间,然后用线段树来维护:感觉算是树链剖分的一种吧,和轻重链剖分不同的是这是对子树进行剖分的. ...

  3. html5 filereader读取流注意事项

    对于截取读入的文件,一定要new FileReader,不可写全局调用同一个reader. 错误代码!!!function readAsBinaryString(file,callback){ rea ...

  4. HDU 4647 Another Graph Game(贪心)

    题目链接 思路题.看的题解. #include <cstdio> #include <string> #include <cstring> #include < ...

  5. div里嵌套了img底部会有白块问题和图片一像素问题解决

    div里嵌套了img底部会有白块 因为img默认是按基线(baseline)对齐的.对比一下图片和右边的p, q, y等字母,你会发现这三个字母的“小尾巴”和图片下方的空白一样高.下面这张图中的黑线就 ...

  6. JQuery获取和设置Select选项常用方法总结 (转)

    1.获取select 选中的 text: $("#cusChildTypeId").find("option:selected").text(); $(&quo ...

  7. JBPM4.4学习API

    一.流程引擎API org.jbpm.api.ProcessEngine是jbpm4所有的Service API 之源. 既所有的Service API(服务接口)都从ProcessEngine中获取 ...

  8. sizeToFit()使用心得

    sizeToFit()使用心得: 很多的初学者,包括我在内,当初在学习的时候,特别纠结什么时候用这个sizeToFit(). 下面我就来分享一下我的一些使用心得. 一.我们先来看看官方文档对sizeT ...

  9. 【转】【Asp.Net MVC】asp.net mvc Model验证总结及常用正则表达式

    本文属转载,来源: http://www.byywee.com/page/M0/S868/868615.html 关于Model验证官方资料: http://msdn.microsoft.com/zh ...

  10. PHP一般情况下生成的缩略图都比较不理想

    PHP用GD库生成高质量的缩略图片,PHP一般情况下生成的缩略图都比较不理想.今天试用PHP,GD库来生成缩略图.虽然并不100%完美.可是也应该可以满足缩略图的要求了.<?php $FILEN ...