Нечеткий поиск в полнотекстовом поиске с помощью mongoosastic - PullRequest
1 голос
/ 20 января 2020

Я работал над сайтом с функцией поиска, которая сопоставляет запросы с различными статьями, представленными в 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);
    }
});

...