程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> Mariadb數據庫 >> 關於mongoose連接mongodb重復訪問報錯的解決辦法

關於mongoose連接mongodb重復訪問報錯的解決辦法

編輯:Mariadb數據庫

具體代碼如下所示:

var express = require('express');
var mongoose = require('mongoose');
var router = express.Router();
var Person = mongoose.model('Person',{
 id:Number,
 name:String
});
/*新增*/
router.get('/insert', function(req, res){
 var student = new Person({
  id:1,
  name:"huop"
 });
 mongoose.connect("mongodb://localhost:27017/test");
 student.save(function(e, product, numberAffected) {
  if (e) res.send(e.message);
  var html = "
新增的數據為:" + JSON.stringify(product);
  html += "
影響的數據量為:" + numberAffected;
  res.send(html);
 });
});
router.get('/find',function(request, response){
 mongoose.connect("mongodb://localhost:27017/test");
 Person.find({
  id: 1
 }, function(e, docs) {
  if (e) response.send(e.message);
  var html = "
 查詢到的數據為:" + JSON.stringify(docs);
  response.send(html);
 });
});

以上代碼可以正常執行,但是有個問題,就是第一次訪問的時候正常,但是刷新一遍就會報錯,Trying to open unclosed connection.undefined
Error: Trying to open unclosed connection.

應該是重復打開連接失敗報錯,所以需要關閉連接,我加了一段關閉連接的代碼,結果查詢結果就成了:查詢到的數據為:unde

那麼該如何處理mongodb數據庫連接?

解決辦法如下所示:

新建一個mongoose.js:

var mongoose = require(‘mongoose');
mongoose.connect(‘mongodb://localhost/nuaidibi');
module.exports = mongoose;

每個module中,引用

var mongoose = require('./mongoose.js');下面使用就一樣了,不用開關連接。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved