平凡之路

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. 游戏 window

    using UnityEngine; using System.Collections; public class YY : MonoBehaviour { ,,,); ,,,); // Use th ...

  2. String, StringBuffer, StringBuilder(转载)

    http://blog.csdn.net/rmn190/article/details/1492013 String 字符串常量StringBuffer 字符串变量(线程安全)StringBuilde ...

  3. 【COGS】147. [USACO Jan08] 架设电话线(二分+spfa)

    http://cojs.tk/cogs/problem/problem.php?pid=147 学到新姿势了orz 这题求的是一条1-n的路径的最大路径最小. 当然是在k以外的. 我们可以转换一下. ...

  4. 【BZOJ】1901: Zju2112 Dynamic Rankings(区间第k小+树状数组套主席树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1901 首先还是吐槽时间,我在zoj交无限tle啊!!!!!!!!我一直以为是程序错了啊啊啊啊啊啊. ...

  5. BZOJ3925: [Zjoi2015]地震后的幻想乡

    Description 傲娇少女幽香是一个很萌很萌的妹子,而且她非常非常地有爱心,很喜欢为幻想乡的人们做一些自己力所能及的事情来帮助他们. 这不,幻想乡突然发生了地震,所有的道路都崩塌了.现在的首要任 ...

  6. libtiff 生成48位色tif图片

    BOOL CTifImage_48Bits::BitmapConvertTo48BitsTif(CString strImagePath, int nWidth, int nHeight, int n ...

  7. Js操作Select大全

    判断select选项中 是否存在Value="paraValue"的Item 向select选项中 加入一个Item 从select选项中 删除一个Item 删除select中选中 ...

  8. C#输入的字符串只包含汉字

    public  bool IsAllChineseCh(string input)        {            Regex regex = new Regex("^[\u4e00 ...

  9. 利用openSSL 生成RSA公钥和密钥

    安装openssl for Windows. 之后开管理员控制台,打开openSSL 我的是 C:\OpenSSL-Win32\bin\openssl.exe 生成1024位的私钥,不指定的话默认20 ...

  10. Java泛型总结

    1. 什么是泛型?泛型(Generic type 或者 generics)是对 Java 语言的类型系统的一种扩展,以支持创建可以按类型进行参数化的类.可以把类型参数看作是使用参数化类型时指定的类型的 ...