指定相同运算符的具有多个表达式的mongo查询

时间:2018-10-16 02:57:02

标签: node.js mongodb mongodb-query nodes node-modules

您好,我正在尝试在数据库中执行以下查询

function getChat(nameChat, nameUser, callback) {
global.db.collection('chatUsers').find({ 
    $and: [ 
        { $or : [ { nameChat: nameChat }, { nameChat: nameUser } ] },
        { $or : [ { nameUser: nameChat }, { nameUser: nameUser } ] }
    ]
}).sort({date: 1}).toArray(
    function (err, docs) {
        if (err) return console.log("algo deu errado" + err);
        console.log("exit\n"+docs+nameUser);
        callback(docs);
    }
);}

但是查询返回空值这是我在聊天用户集合中拥有的对象的示例:

{"_id":"5bc3e6d060d4da04dcd66517","nameChat":"Daciolo bolsominion","nameUser":"Mc Xhamps","date":"2018-10-14T17:22:00.000Z","msg":"Você pertence a URSAL"}

{"_id":"5bc52fc3b878631f84c77c41","nameChat":"Mc Xhamps","nameUser":"Daciolo bolsominion","date":"2018-10-01T17:25:00.000Z","msg":"E ai, bora ser Presidente"}

为清楚起见,我希望查询返回所有名称为Chat或Name User的对象都存在于同一对象中 此查询仅返回空对象。

1 个答案:

答案 0 :(得分:0)

嘿,埃里克(Erik)用和更改和,您将得到所需的结果。

global.db.collection('chatUsers').find({ 
    $or: [ 
        { $or : [ { nameChat: nameChat }, { nameChat: nameUser } ] },
        { $or : [ { nameUser: nameChat }, { nameUser: nameUser } ] }
    ]
}).sort({date: 1})