在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

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

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

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

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

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

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

clipboard.png

回答
編輯回答
傻丟丟

問(wèn)題描述的不是很清楚

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

不知是否幫到你,可以留言讓我進(jìn)一步了解你的問(wèn)題。

補(bǔ)充回答:

以nodejs的express框架action請(qǐng)求為例:

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
                });
            });
        }
        
    });
    
}

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

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

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

2018年8月28日 06:37