sql >> Databasteknik >  >> NoSQL >> MongoDB

MongooseJS/MongoDB sök exakt fras

Jag tror att du har rätt i att det är lättast att kontrollera att första och sista tecknet är citattecken. Men mongoose själv kan inte göra detta. Jag föreslår att du förbereder frågan i förväg och även väljer lämplig hit metod.

Vi kan också använda $regex operatorn för att utföra det givna reguljära uttrycket mot "keyword"-egenskapen för varje dokument i samlingen.

var userInput = '"Apple"';
var term = userInput.trim(); 
var caseInsensitive = true; // = some user input?

var isExactTerm = (function() {
    var firstChar = term[0];
    var lastChar = term[term.length - 1];
    return (firstChar === '"' && lastChar === '"');
}();

if(isExactTerm) {
    // Remove quotes from the query
    term = term.substr(1, str.length - 1);
}

var method = (isExactTerm) ? 'findOne': 'find';
var regexFlags = (caseInsensitive) ? 'i' : '';
var query = (isExactTerm) ? term : {$regex: new RegExp(term, regexFlags)};

Model[method]({
    keyword: query
}).exec().then(function(result) {
    // do stuff with `result`
}, function(err) {
    // handle `err`
});



  1. Mongo-fråga för att sortera efter distinkt antal

  2. Ta bort ett underdokument från array i MongodDB

  3. Hur skickar socket.io meddelanden över flera servrar?

  4. MapReduce verkar begränsade till 100?