目录

1、准备工作。

2、配置Mongoose。

3、创建目录及文件。

4、插入数据,POST提交JSON增加一条记录。

5、查询数据,取出你插入数据库的记录。

一、准备工作

使用Express4创建项目,ejs作为视图引擎。

二、配置Mongoose

1、安装Mongoose类库:npm install mongoose --save。

2、创建models文件夹,在models文件夹下新建mongodb.js文件。

 var mongoose=require('mongoose');
mongoose.connect('mongodb://localhost:27017/nodejs'); exports.mongoose=mongoose;

三、创建目录及文件

1、在models目录,创建数据模型Movie.js,也就是我们通常想扮演的Dao角色。

 var mongodb=require('./mongodb');
var Schema=mongodb.mongoose.Schema; var MovieSchema=new Schema({
name:String,
alias:[String],
publish:Date,
create_date:{type:Date,default:Date.now},
images:{
converSmall:String,
converBig:String
},
source:[{
source:String,
link:String,
swfLink:String,
quality:String,
version:String,
lang:String,
subtitle:String,
create_date:{type:Date,default:Date.now}
}]
}); var Movie=mongodb.mongoose.model("Movie",MovieSchema);
var MovieDao=function(){}; /*******
保存
********/
MovieDao.prototype.save=function(obj,callback){
var instance=new Movie(obj);
instance.save(function(err){
callback(err);
})
}
/**
按照电影名称精确查询
**/
MovieDao.prototype.findByName=function(name,callback){
Movie.findOne({name:name},function(err,obj){
callback(err,obj);
});
} module.exports=new MovieDao();

2、打开app.js 完善路由地址

var express = require('express');
var path = require('path');
var favicon = require('serve-favicon');
var logger = require('morgan');
var cookieParser = require('cookie-parser');
var bodyParser = require('body-parser'); var routes = require('./routes/index');
var users = require('./routes/users');
var movie=require('./routes/movie'); var app = express(); // view engine setup
app.set('views', path.join(__dirname, 'views'));
app.set('view engine', 'ejs'); // uncomment after placing your favicon in /public
//app.use(favicon(path.join(__dirname, 'public', 'favicon.ico')));
app.use(logger('dev'));
app.use(bodyParser.json());
app.use(bodyParser.urlencoded({ extended: false }));
app.use(cookieParser());
app.use(express.static(path.join(__dirname, 'public'))); //app.use('/', routes);
//app.use('/users', users);
app.get('/',movie.movieAdd);
app.get('/movie/add',movie.movieAdd);
app.post('/movie/add',movie.doMovieAdd);
app.get('/movie/:name',movie.movieAdd);
app.get('/movie/json/:name',movie.movieJson); // catch 404 and forward to error handler
app.use(function(req, res, next) {
var err = new Error('Not Found');
err.status = 404;
next(err);
}); // error handlers // development error handler
// will print stacktrace
if (app.get('env') === 'development') {
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: err
});
});
} // production error handler
// no stacktraces leaked to user
app.use(function(err, req, res, next) {
res.status(err.status || 500);
res.render('error', {
message: err.message,
error: {}
});
}); module.exports = app; app.listen(3000,function(){
console.log('server begin...');
})

3、在routes目录增加movie.js

var Movie=require('./../models/Movie.js');

exports.movieAdd=function(req,res){
if(req.params.name){
return res.render("movie",{
title:req.params.name+'|电影|管理|movie.me',
label:'编辑电影'+req.params.name,
movie:req.params.name
});
}else{
return res.render("movie",{
title:'新增加|电影|管理|movie.me',
label:'新增加电影',
movie:false
});
}
} exports.doMovieAdd=function(req,res){
console.log(JSON.parse(req.body.content));
var json=JSON.parse(req.body.content); //把客户端的Json字符串转化为object
if(json._id){
//update
}
else{
//insert
Movie.save(json,function(err){
if(err){
res.send({'success':false,'err':err})
}else{
res.send({'success':true})
}
})
}
} exports.movieJson=function(req,res){
Movie.findByName(req.params.name,function(err,obj){
res.send(obj);
})
}

4、在views目录,增加movie.ejs视图。

<% include head.ejs %>
<div class="container-fluid">
<div class="row-fluid">
<div class="span8">
<form>
<fieldset>
<legend><%=label%></legend>
<textarea name="editor" id="editor" class="span12" rows="10" cols="60" <%=(movie?'"movie='+movie+'"':'')%> ></textarea>
</fieldset>
<br>
<button id="save" type="button" class="btn btn-primary">保存</button>
</form>
</div>
</div>
</div>
<span id='msg'></span> <% include footer.ejs %>

运行起来看看页面效果 http://localhost:3000

四、插入数据,POST提交JSON增加一条记录

1、基础环境搭建好后,别忘了启动mongodb服务。在这里还有个地方,如果你使用的是express4.0框架,那么从页面向路由里传对象时需要在客户端里用JSON.Stringify序列化对象,然后在路由文件里使用JSON.Parse把字符串转化为对象。本地直接创建一个JSON对象,直接读取这个JSON文件插入数据库。在public/javascripts下创建movie.json。

创建好JSON文件后,我在本地使用了head.ejs和footer.ejs ,别忘了在footer.ejs里引用要使用的js文件,我这里使用了jquery、bootstrap、jquery.json、movie.js(后面创建)。

{
"name": "未来警察",
"alias": ["Future X-Cops ","Mei loi ging chaat"],
"publish": "2010-04-29",
"images":{
"coverBig":"/img/movie/1_big.jpg",
"coverSmall":"/img/movie/1_small.jpg"
},
"source":[{
"source":"优酷",
"link":"http://www.youku.com",
"swfLink":"http://player.youku.com/player.php/sid/XMTY4NzM5ODc2/v.swf",
"quality":"高清",
"version":"正片",
"lang":"汉语",
"subtitle":"中文字幕"
},{
"source":"搜狐",
"link":"http://tv.sohu.com",
"swfLink":"http://share.vrs.sohu.com/75837/v.swf&topBar=1&autoplay=false&plid=3860&pub_catecode=",
"quality":"高清",
"version":"正片",
"lang":"汉语",
"subtitle":"中文字幕"
}]
}

2、在public/javascripts目录里增加movie.js作为客户端访问脚本。 客户端初始化时读取json文件。

 $(function(){
var mdata={};
var url='/javascripts/movie.json'; var movie=$('#editor').attr('movie');
if(movie){
url='/movie/json/'+movie;
} $.getJSON(url,function(data){
mdata=data;
render_editor_form(data);
render_event_form();
}); var render_editor_form=function(data){
$('#editor').val($.toJSON(data));
}; var render_event_form=function(){
$('#save').on('click',function(event){
var data={};
data.content=JSON.stringify(mdata);
$.ajax({
type:'POST',
url:'/movie/add',
dataType:'json',
data:data,
success:function(data,status){
if(data.success){
$('#msg').html('保存成功');
$('#msg').addClass('href','/movie/'+data.name);
}else{
$('#msg').html(data.err);
$('#msg').addClass('alert alert-error');
}
}
});
});
};
});

启动浏览器看看效果:

3、在models目录增加Movie.js 也就是我们操作数据库的地方,增加save()。

/*******
保存
********/
MovieDao.prototype.save=function(obj,callback){
var instance=new Movie(obj);
instance.save(function(err){
callback(err);
})
}

4、在routes/movie.js里调用save()

exports.doMovieAdd=function(req,res){
console.log(JSON.parse(req.body.content));
var json=JSON.parse(req.body.content); //把客户端的Json字符串转化为object
if(json._id){
//update
}
else{
//insert
Movie.save(json,function(err){
if(err){
res.send({'success':false,'err':err})
}else{
res.send({'success':true})
}
})
}
}

页面启动起来,直接点击保存按钮,查看报文,插入成功后会返回success:true。插入成功后你可以用DOS命令来检查,也可以用可视化工具来查看,后面在页面里调用也可以。

五、查询数据,取出你插入数据库的记录

1、在models/Movie.js里增加findByName()用来查看你刚才插入数据库的记录,这里使用电影名称来查看。

/**
按照电影名称精确查询
**/
MovieDao.prototype.findByName=function(name,callback){
Movie.findOne({name:name},function(err,obj){
callback(err,obj);
});
}

2、在routes/movie.js里调用findByName()

 exports.movieJson=function(req,res){
Movie.findByName(req.params.name,function(err,obj){
res.send(obj);
})
}

写完调用后,你可以在浏览器里输入http://localhost:3000/movie/json/未来警察 ,会返回你刚才入库的数据。

总结

使用Mongodb我发现最灵活的莫过于数据结构了,原文是用的express3,然后我做的时候用的express4,在路由里使用req.body.content提示undefined。后来查询因为Express版本的时,所以就用了JSON.Stringify和JSON.parse()。

原文地址:http://blog.fens.me/nodejs-mongoose-json/

Mongoose使用案例--让JSON数据直接入库MongoDB的更多相关文章

  1. MongoDB 将Json数据直接写入MongoDB的方法

    Json转Bson MongoDB中是以Bson数据格式进行存储的,Json字符串没有办法直接写入MongoDB 可以将Json字符串转换成DBObject或者Document,然后写入MongoDB ...

  2. 10.MongoDB:将Json数据直接写入MongoDB的方法

    Json转Bson MongoDB中是以Bson数据格式进行存储的,Json字符串没有办法直接写入MongoDB 可以将Json字符串转换成DBObject或者Document,然后写入MongoDB ...

  3. kettle批量导入json数据

    kettle新手上路,烦死了,工具好用,批量导入数据也快,就是有很多小细节需要注意. 使用kettle进行数据导入时,因为最近在做json数据的入库,以JSON Input为例进行说明: 首先是大概流 ...

  4. 【clickhouse专栏】对标mongodb存储类JSON数据文档统计分析

    一.文档存储的需求 很多的开发者都使用过mongodb,在mongodb中数据记录是以文档的形式存在的(类似于一种多级嵌套SQL的形式).比如下面的JSON数据结构:dev_ip表示某一台服务器的ip ...

  5. ajax请求json数据案例

    今天有这样一个需求,点击六个大洲,出现对应的一些请求信息,展示在下面,请求请求过后,第二次点击就无需请求.如图所示:点击北美洲下面出现请求的一些数据 html代码结构: <div class=& ...

  6. jQuery实例之ajax请求json数据案例

    今天有这样一个需求,点击六个大洲,出现对应的一些请求信息,展示在下面,请求请求过后,第二次点击就无需请求.如图所示:点击北美洲下面出现请求的一些数据 html代码结构: <div class=& ...

  7. android基础---->JSON数据的解析

    上篇博客,我们谈到了XML两种常用的解析技术,详细可以参见我的博客(android基础---->XMl数据的解析).网络传输另外一种数据格式JSON就是我们今天要讲的,它是比XML体积更小的数据 ...

  8. Android中Json数据读取与创建

    一:  Json的特性和在数据交互中的地位就不用说了,直接看案例. 首先在android studio中创建assets文件目录,用于存放Json数据文件,android studio 1.3 默认项 ...

  9. Android(java)学习笔记208:Android中操作JSON数据(Json和Jsonarray)

    1.Json 和 Xml       JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于ECMAScript的一个子集. JSON采用完全独立于语言的 ...

随机推荐

  1. HTML实现简单计算器

    <!DOCTYPE html> <html> <meta name="content-type" content="text/html; c ...

  2. 学习笔记: Delphi之线程类TThread

    新的公司接手的第一份工作就是一个多线程计算的小系统.也幸亏最近对线程有了一些学习,这次一接手就起到了作用.但是在实际的开发过程中还是发现了许多的问题,比如挂起与终止的概念都没有弄明白,导致浪费许多的时 ...

  3. Visual Studio “14” CTP 4

    微软发布于10月6日发布了Visual Studio "14"CTP 4,本次发布的更新主要包括:ASP.NET vNext runtime和一些工具的优化(ASP.NET vNe ...

  4. 开放式管理基础结构 OMI

    Windows 长久以来在 CIM 实施领域一直傲立桥头,而这一切都是从 WMI(Windows 管理基础结构)开始的.分布式管理任务组 (DMTF) 通用信息模型 (CIM) 是一种开放式标准,用于 ...

  5. 可在广域网部署运行的QQ高仿版 -- GGTalk总览

     (最新版本:V5.5,2016.12.06  增加对MySQL数据库的支持.) (android移动端:2015.09.24 最初发布 ,2016.11.25 最后更新) GGTalk(简称GG)是 ...

  6. 【大型网站技术实践】初级篇:搭建MySQL主从复制经典架构

    一.业务发展驱动数据发展 随着网站业务的不断发展,用户量的不断增加,数据量成倍地增长,数据库的访问量也呈线性地增长.特别是在用户访问高峰期间,并发访问量突然增大,数据库的负载压力也会增大,如果架构方案 ...

  7. 说说Java程序和数据库交互的乱码解决

    本文就本人遇到的问题进行讲解 1.通过jdbc直连方式,连接Mysql数据库,从程序向数据库中写入数据出现的乱码解决方案. 当通过程序向Student表中写入一条数据时,写入数据库的内容会产生乱码. ...

  8. 提供程序不支持 DatabaseExists

    如果Oracle CodeFirst模式下要用EFProviderWrapperToolkit,那么会报告以下错误: 提供程序不支持 DatabaseExists. 这个错误是因为Oracle Cod ...

  9. JavaScript学习笔记之string

    字符串定义: 1,var myString=“内容”:or var myString=‘内容’ 2,var myString= new String(“内容”)           ---〉创建对象, ...

  10. Objective-C 外观模式--简单介绍和使用

    外观模式(Facade),为子系统中的一组接口提供一个一致的界面,定义一个高层接口,这个接口使得这一子系统更加容易使用. 在以下情况下可以考虑使用外观模式: (1)设计初期阶段,应该有意识的将不同层分 ...