nodejs中原生方式连接mongodb,并执行查询

nodejs连接mongodb并且进行增删改查操作,可以用到mongoose。mongoose使用的前提是有配置文件,去提前创建好Schema对象,也就是说表结构和表名必须是提前确定的。

但是有时候,可能表是实时生成的,也就是说表名是动态不确定的,比如我们统计好多个公司的业务数据,有新公司接入系统,我们就要自动生成一个表,表名是company+公司id,因此这个时候就要用到原生的node连接mongo查询的方式。

 

nodejs中原生方式连接mongodb有两种:

1. 旧版本mongo是new mongodb.Server()的方式

2. 新版本是通过MongoClient方式

我们建议用2新版本的方式,使用如下:

// 数据库配置
var mongodb = require('mongodb');
var MongoClient = mongodb.MongoClient;
// 用户名:密码@ip/dbname
var dburl = "mongodb://"+config.mongouname + ":" + config.mongopasswd +"@" + config.mongoHost + ":27017/" + config.dbname;
MongoClient.connect(dburl, function(err, server) {
	if(err){
		console.log("数据库连接失败");
        throw err;
    }
	var db = server.db(config.dbname);
	db.collection(collectionName).find().toArray(function(err, allInfo){
		// collectionName是表名
	});
	    
});

注意这里有个版本问题,在mongo3.2版本中dburl末尾必须加/dbname,不加的话一致报错"authentication failed", 在mongo3.6和4.x版本里不用加也行,为了一致建议都加上。

node的mongo连接使用,可以参考官方文档:

http://mongodb.github.io/node-mongodb-native/2.0/tutorials/aggregation/

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值