admin管理员组文章数量:1338664
I have store two field FirstName and LastName stored in MongoDB.from Frontend, I am receiving a string containing both first name and last name separated by space I need a find query which searches both first name & last name bined.
here is eg. scenario
in DB I have following object
{ firstName: "Hemant Kumar", lastName: "Rajpoot" };
if i receive "Hemant Kumar Rajpoot"
it should match.If possible please don't give solution with aggregeation.
I have store two field FirstName and LastName stored in MongoDB.from Frontend, I am receiving a string containing both first name and last name separated by space I need a find query which searches both first name & last name bined.
here is eg. scenario
in DB I have following object
{ firstName: "Hemant Kumar", lastName: "Rajpoot" };
if i receive "Hemant Kumar Rajpoot"
it should match.If possible please don't give solution with aggregeation.
- This post can be a duplicate of another. Check this one: stackoverflow./questions/15495368/… – medkhelifi Commented Sep 18, 2019 at 7:29
5 Answers
Reset to default 15You can use $regexMatch
if you are using latest mongodb version 4.2
db.collection.find({
"$expr": {
"$regexMatch": {
"input": { "$concat": ["$first", " ", "$last"] },
"regex": "a", //Your text search here
"options": "i"
}
}
})
MongoPlayground
You can do it with bination of $expr, $eq and $concat.
Example:
db.yourCollection.find({
$expr: {
$eq: [
{$concat: ["$firstName", " ", "$lastName"]},
"Hemant Kumar Rajpoot" // your full name to search here
]
}
})
If you would like to do it using aggregation. here is an example
db.user.aggregate(
[
{
$project : {
fullname: {$concat: ["$firstname", " ", "$lastname"]}
},
},
{
$match : {
fullname: "your full name"
}
}
]
)
Searching from Both Two Fields (First Name & Last Name) in MongoDB prioritising the First Names;
Previously, The Search Results Prioritised the Last Names First, since the search was Alphabetical. Now I've Combined the Results for both but vice versa, (The Intuitive Way).
Can It be Solved Better to be more efficient or optimised, Just a newbie asking.
Suggest me a Better Search Function/Algo if you know. (Please)
globalSearch: function (q, id) {
return new Promise(async (resolve, reject) => {
q = q.toString();
q = q.trim();
var y = q.indexOf(' ') > 0;
var firstParam, secondParam;
var searchQuery, searchQuery1, searchQuery2;
var users = {};
if (y) {
q = q.split(" ");
firstParam = q[0];
secondParam = q[1];
searchQuery = {
is_activated: true,
"privacy.is_profile_public": true,
"privacy.block_list": { $ne: id },
$and: { fname: { "$regex": firstParam, "$options": "i" } }, { lname: { "$regex": secondParam, "$options": "i" } },
}
User.find(searchQuery, function (err, users) {
if (err || !users) {
return reject({
status: 404,
message: "User not found",
});
}
return resolve(users);
},
).sort({ fname: 1 }).collation({ locale: "en", caseLevel: true }).sort({ lname: 1 }).collation({ locale: "en", caseLevel: true });
}
else {
searchQuery1 = {
is_activated: true,
"privacy.is_profile_public": true,
"privacy.block_list": { $ne: id },
fname: { "$regex": q, "$options": "i" },
};
searchQuery2 = {
is_activated: true,
"privacy.is_profile_public": true,
"privacy.block_list": { $ne: id },
lname: { "$regex": q, "$options": "i" },
};
userslist1 = await this.searchCompanion1(searchQuery1);
userslist2 = await this.searchCompanion2(searchQuery2);
users = userslist1 + userslist2
return resolve(users);
}
});
},
searchCompanion1: function (Q) {
return new Promise((resolve, reject) => {
User.find(Q, function (err, users) {
if (err || !users) {
console.log(err);
}
return resolve(users);
},
).sort({ fname: 1 }).collation({ locale: "en", caseLevel: true }).sort({ lname: 1 }).collation({ locale: "en", caseLevel: true });;
});
},
searchCompanion2: function (Q) {
return new Promise((resolve, reject) => {
User.find(Q, function (err, users) {
if (err || !users) {
console.log(err);
}
return resolve(users);
},
).sort({ fname: 1 }).collation({ locale: "en", caseLevel: true }).sort({ lname: 1 }).collation({ locale: "en", caseLevel: true });;
});
},
It's as simple as checking if the fields entered (firstname
, lastname
) matches any user in the database.
module.exports.checkFullName = (req, res, next) => {
myCollection.findOne({ firstName: req.firstname, lastName: req.lastname },
(err, user) => {
if (!user)
return res.status(404).json({ status: false, message: 'User not found' });
else
return res.status(200).json({ status: true, user });
}
);
}
本文标签: javascriptFirst Name and Last Name Combine search in mongoDBStack Overflow
版权声明:本文标题:javascript - First Name and Last Name Combine search in mongoDB - Stack Overflow 内容由网友自发贡献,该文观点仅代表作者本人, 转载请联系作者并注明出处:http://www.betaflare.com/web/1743551110a2501655.html, 本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容,一经查实,本站将立刻删除。
发表评论