Я работал над сайтом с функцией поиска, которая сопоставляет запросы с различными статьями, представленными в MongoDB. В настоящее время mongoDB не поддерживает нечеткий поиск с помощью функции поиска. Для этого я обнаружил, что Elasticsearch лучше всего работает с этим типом проблемы. Для этой цели я использовал клиент mongoosasti c для node.js. Мне удалось сохранить элемент данных и выполнить поиск по запросу, но он не может выполнить поиск, если в нем присутствует какая-либо орфографическая ошибка. Как настроить запрос, который поможет найти текст даже при отсутствии опечатки или слова.
const mongoose = require('mongoose');
const mongoosastic = require('mongoosastic');
mongoose.connect('mongodb://localhost:27017/mongosync');
var UserSchema = new mongoose.Schema({
name: String
, email: String
, city: String
});
UserSchema.plugin(mongoosastic, {
"host": "localhost",
"port": 9200
}, {hydrate:true, hydrateOptions: {lean: true}});
var User = mongoose.model('user', UserSchema);
// User.createMapping((err, mapping) => {
// console.log('mapping created');
// });
// var newUser = new User({
// name: 'Abhishek',
// email: 'abhishek.patel@company.com',
// city: 'bhopal'
// });
// newUser.save((err) => {
// if(err) {
// console.log(err);
// }
// console.log('user added in both the databases');
// })
// newUser.on('es-indexed', (err, result) => {
// console.log('indexed to elastic search');
// });
User.search(
{query_string: {query: "abheshek"}},
function(err, results) {
if(err){
console.log('ERROR OCCURED');
} else {
console.log(results);
}
});