0

私はmongodbを初めて使用し、単純な問題と思われる問題を抱えていますが、Googleは関連していないように見える一連のmapreduceシナリオを提供しています。

ドキュメントを含むコレクションがあります。いずれかのフィールドで検索しようとすると、エラーが発生します。

> db.users.find('u_email', "")
error: { "$err" : "ReferenceError: u_email is not defined", "code" : 16722 }

次に、mongoDB は次のようなエラーを出力します。

Tue Dec 03 02:55:13.085 [conn1] assertion 16722 ReferenceError: u_email is not defined ns:test.users query:{ $where: "u_email" }

私のマングース ユーザー スキーマには u_email フィールドがあります。

var userSchema = new mongoose.Schema({
    'u_id'      : {type:String, unique:true},
    'u_email'   : {type:String, required:true, unique:true}, 
    'u_name'    : {'first'  : {type:String}, //first name
                   'last'   : {type:String} //last name 
                  },
});

ここで何が起こっているのかわかりません。app.js で mongoose を使用して findOne() を実行しようとしましたが、何も表示されません。正しい _id を返しますが、他には何も返さないため、奇妙です。

var email = email@dns.com;
User.findOne('u_email', email).exec(function (err, doc) {
    console.log(doc);
}

結果:

{ _id: 529d8cfb03820d5410000002, u_name: {} }

参照用に私の db.users.getIndexes() を次に示します。

> db.users.getIndexes()
[
        {
                "v" : 1,
                "key" : {
                        "_id" : 1
                },
                "ns" : "test.users",
                "name" : "_id_"
        },
        {
                "v" : 1,
                "key" : {
                        "u_id" : 1
                },
                "unique" : true,
                "ns" : "test.users",
                "name" : "u_id_1",
                "background" : true,
                "safe" : null
        },
        {
                "v" : 1,
                "key" : {
                        "u_email" : 1
                },
                "unique" : true,
                "ns" : "test.users",
                "name" : "u_email_1",
                "background" : true,
                "safe" : null
        }
]
4

1 に答える 1

2

MongoDB シェルのクエリ形式は次の{ KEY : VALUE, ... }とおりです。

> db.users.find({ 'u_email' : '' })

同様にマングースの場合:

User.findOne({ 'u_email' : email }).exec(function (err, doc) {
  console.log(doc);
});
于 2013-12-03T10:16:43.853 に答える