设为首页 收藏本站
查看: 1639|回复: 0

[经验分享] 从零开始优雅的使用mongodb实例

[复制链接]

尚未签到

发表于 2017-12-15 23:30:29 | 显示全部楼层 |阅读模式
  基本连接
  一、创建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");  
});
  

DSC0000.png

  三:进入工程目录安装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('成功插入数据');
  
}
  
});
  
/************/
  

DSC0001.png

  打开另外一个cmd窗口,先查询一次数据,然后重新启动工程,再查询一次数据发现数据成功添加上了
DSC0002.png

  分离改造
  下面我们把它改装为一访问http://localhost:3000/add就自动添加数据,思路
DSC0003.jpg

DSC0004.png

  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;
  

DSC0005.png

  路由里因为用到kittyModel所以引入要在mongoose初始化后,不然会提示出错“Schema hasn't been registered ...”, 自己把上面的顺序调换测试下更深刻噢~
  温馨提示:测试多了,不妨使用db.table.drop() 把整个集合删除掉噢
  相关文章:
  安装express并创建工程
  window平台安装MongoDB
  下载地址

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-424537-1-1.html 上篇帖子: mongodb 压缩——3.0+支持zlib和snappy 下篇帖子: mongodb安装启动遇到的问题
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表