鍍金池/ 問答/數(shù)據(jù)庫  HTML/ 前端默認傳空字符串,mongodb如何查詢所有數(shù)據(jù)

前端默認傳空字符串,mongodb如何查詢所有數(shù)據(jù)

前端頁面如下:
clipboard.png
用vue寫的,默認查詢發(fā)送給后臺的數(shù)據(jù)如下:

email:"",
mis:"",
phone:"",
username:"",

后臺node寫的,接收之前還是空字符串,如何在數(shù)據(jù)庫中默認查詢出所有數(shù)據(jù)呢?是把以下數(shù)據(jù)默認都查詢出來,而不是制定符合字段為空字符串的相對應(yīng)字段??
clipboard.png

有沒有像如下mysql的語句,判斷參數(shù)是否為空,全部為空就查全部,有不為空的就帶條件查詢

clipboard.png

回答
編輯回答
傻丟丟

問題描述的不是很清楚

如果你想做的事情是: 當前端傳入的數(shù)據(jù)為空字符串時,在查詢時不對此字段做限制,只對前端傳了非空的字段進行限制的話, mongodb的find方法是需要傳一個給定值的,傳空字符串 會匹配此字段為空的記錄, 你需要在執(zhí)行db查詢操作之前,
在nodejs代碼中判斷字符串是否為空,然后再執(zhí)行查詢語句。

不知是否幫到你,可以留言讓我進一步了解你的問題。

補充回答:

以nodejs的express框架action請求為例:

const mongoClient = require('mongodb').MongoClient;
module.exports.get = function (req, res, next) {
    let queryEmail = req.query.email;
    
    mongoClient.connect(url, function (err, db) {
        if (err) throw error;
        let col = db.collection('your_collection');
        if (typeof queryEmail === 'string' && queryEmail.length === 0) {
            col.find({}).toArray(function (err, list) {
                if (err) throw error;
                res.json({
                    data: list
                });
            });
        }
        else {
            col.find({ email: queryEmail }).toArray(function (err, list) {
                if (err) throw error;
                res.json({
                    data: list
                });
            });
        }
        
    });
    
}

以上代碼只是幫你打個樣,僅對于email這一個字段的查詢, 當輸入為空字符串時,直接將查詢條件設(shè)為了空對象,因此不對任何字段做限制輸出查詢結(jié)果;如果email字段里有貨,則在查詢條件中限制email字段必須符合輸入值。
有問題請回復(fù)。

2017年3月16日 09:45
編輯回答
眼雜
var query={};
if(email){
query.email=email
}
if(username){
query.username=username
}
//其他字段同樣處理。

意思就是,在判斷不為空時再組裝限制條件。

2018年8月28日 06:37