3

次のnode.jsのコードを使用してmongoDBに接続し、node.jsコンソールに表示されるメッセージを「mytable」というコレクションに挿入したいと考えています。私が直面している問題は、mongoDB に正常に接続され、node.js コンソールに表示されるメッセージも挿入されますが、1 つの完全なドキュメントとして挿入されるのではなく、文字として挿入されることです。なぜそれが起こっているのですか?助けてください

var mongo = require("mongodb");
var dbhost = "127.0.0.1";
var dbport = mongo.Connection.DEFAULT_PORT;
var db = new mongo.Db("mydb", new mongo.Server(dbhost, dbport, {}), {safe: true});
db.open(function(error){
        status = ("db connected at" + dbhost + " : " + dbport);
        console.log(status);

        db.collection("mytable",function (error,collection){

        collection.insert(status, function(error){

            if (error){
                console.log("Error : ", error.message);
            } else {
                console.log("Inserted in to database");
                } 

            });
        }); 


});

私のノードコンソールの表示出力

db connected at127.0.0.1 : 27017
Inserted in to database

コマンドで「mytable」mongoシェルをチェックしている間

db.mytable.find.forEach(printjson)

次の出力が表示されています

{

"_id" : objectId("5207741d193770459f068317"),
"0" : "d",
"1" : "b",
"3" : " ",
"4" : "c",
"5" : "o",
"6" : "n",
"7" : "e",
"8" : "c",
"9" : "t",
"10" : "e",

"28" : "7",
"29" : "0",
"30" : "1",
"31" : "7"

}

1 つのエントリ、つまり 'db connected at 127.0.0.1 : 27017' だけを mytable に単一のドキュメントとして挿入するのを手伝ってください。

4

1 に答える 1

1

Mongo は、string挿入しようとしている をBSON ドキュメント(したがってオブジェクト) として扱い、ドキュメント フィールドとして扱うプロパティを反復処理します。

プロパティとして必要な値を持つ実際のオブジェクトを挿入してみてください。

collection.insert({status: status}, function(error){

        if (error){
            console.log("Error : ", error.message);
        } else {
            console.log("Inserted in to database");
            } 

        });
    }); 
于 2013-08-11T11:57:01.000 に答える