Mongo没有使用nodejs

时间:2014-12-14 22:33:30

标签: javascript node.js mongodb mongodb-query

我正在处理一个简单的问题,即使用Node.js 在 Mongo数据库中插入集合。但是我面临两个问题:

1.当我在.insert函数中使用{safe:true}时(下面:albums.insert(a1, {safe: false}, cb);
albums.insert(a2, {safe: false}, cb);),集合不会插入到数据库中,即它们不会当我console.log(doc)(请参阅下面的程序)时,请在终端上打印(
) 2.程序本身不会结束,我必须按ctrl + c结束它,即使它最后有db.close(),我可以看到" here"打印在console.logged

之后db.close()的终端上

非常感谢任何帮助,谢谢!

var Db= require('mongodb').Db,
Connection= require('mongodb').Connection,
Server= require('mongodb').Server,
async= require('async');

var host= "localhost";
var port= Connection.DEFAULT_PORT;

var db= new Db("PhotoAlbums", new Server(host, port, {auto_reconnect: true,
        poolSize: 20}), {w: 1});

var a1= {_id: "Travel", name: "Travel", title: "Travelogues", description:        
"This was great", date: "1/1/2014"}, 
a2= {_id: "friends", name: "friends", title: "Friends", description:   
"Random Pics", dat: "2/1/2014"};

var albums, photos;

async.waterfall([

function(cb)
{
    db.collection("Albums", cb);    
}, 

function (albums_coll, cb)
{
    albums= albums_coll;
    db.collection("Photos", cb);
},

function (photos_coll, cb)
{
    photos= photos_coll;
    albums.insert(a1, {safe: false}, cb);
},

function (doc, cb)
{ 
    console.log("1. Successfully wrote ");
    console.log(doc);
    albums.insert(a2, {safe: false}, cb);   
},

function (docs, cb)
{ 
    console.log("2. Successfully wrote ");
    console.log(docs);
    cb(null);
},

], function(err, results)
{ 
    if(err)
     console.log("ERROR!");
    db.close();
    console.log("here");
});

1 个答案:

答案 0 :(得分:1)

基本上你从未连接到数据库。 Db对象需要调用.open()方法,并且所有交互都在该方法的提供回调中发生,或者在“连接”事件处理程序中发生。

还有一些概念,你在这里有点偏僻,我想让你直截了当。首先是修订后的清单:

var async = require('async'),
    MongoClient = require('mongodb').MongoClient;


MongoClient.connect('mongodb://localhost/test',function(err,db) {

  var a1 = {
    "_id": "Travel",
    "name": "Travel",
    "title": "Travelogues",
    "description": "This was great",
    "date": new Date("2014/01/01")
  },
      a2 = {
    "_id": "friends",
    "name": "friends",
    "title": "Friends",
    "description": "Random Pics",
    "date": new Date("2014/01/02")
  };

  var albums;

  async.waterfall(
    [
      function(cb) {
        db.collection("albums",cb);
      },

      function(albums_col,cb) {
        albums = albums_col;
        albums.insert(a1,cb);
      },

      function(doc,cb) {
        console.log("1. Successfully wrote");
        console.log(doc);
        albums.insert(a2,cb);
      },

      function(doc,cb) {
        console.log("2. Successfully wrote");
        console.log(doc);
        cb();
      }
    ],
    function(err,results) {
      if (err) throw err;
      db.close();
    }
  );
});

首先,您应该在新代码中使用MongoClient。它是所有语言的标准实现。如果需要,您仍然可以使用Server对象,但连接字符串应该足够正常。交替:

MongoClient.connect( new Server( 
    "localhost",
    Connection.DEFAULT_PORT,
    { "auto_reconnect": true }
    { w: 1 }
),function(err,db) {

    {...}
});

另一部分是我删除了默认设置的选项。更改连接池选项对于此类列表没有任何意义,但是驱动程序中已经内置了默认的5连接而未指定此选项。 “WriteConcern”或{ w: 1 }也是默认值。

其次,在为文档指定的结构中,使用真实日期对象。这些将作为BSON存储的“日期”类型序列化为MongoDB,并且当作为实际日期对象读取时它们也会返回到您的代码中。这就是你想要的日期。否则这些只是字符串而不是非常有用。

不是为集合声明变量而不是将参数传递给回调的忠实粉丝,而是为了简洁而保持相同。

请注意{ safe: true }方法的WriteConcern部分中遗漏.insert()。除非你真的想要覆盖连接的设置(你应该很少想要),否则你可能只想使用默认设置。 “安全”选项也已弃用,因此您应该编写等效的{ w: 0 }

但最后请注意,如果您选择{ w: 0 },则不会返回您写入的文档的预期“响应”。即使将值写入数据库,该值也将报告为null。这是因为这种“不安全”的写入方式不需要来自数据库的任何确认。所以你只是假设它在那里,因此可能需要默认值{ w: 1 },这意味着它已被确认。

然后按预期输出:

1. Sccessfully wrote
[ { _id: 'Travel',
    name: 'Travel',
    title: 'Travelogues',
    description: 'This was great',
    date: Wed Jan 01 2014 00:00:00 GMT+1100 (AEDT) } ]
2. Sccessfully wrote
[ { _id: 'friends',
    name: 'friends',
    title: 'Friends',
    description: 'Random Pics',
    date: Thu Jan 02 2014 00:00:00 GMT+1100 (AEDT) } ]

当然,取决于您在字符串化输出中的实际时区。另请注意,new Date("2014/01/01")new Date("2014-01-01")的形式并不相同。第一个将日期构建为UTC时区对象,第二个将在您的本地时区构建。 MongoDB将存储UTC,因此最好确保您的构造以您存储的任何数据形成。