sql >> Databáze >  >> NoSQL >> MongoDB

MongoDB:Nerozlišuje se malá a velká písmena a nerozlišuje se přízvuk

doporučuji vytvořit textový index s výchozím jazykem nastaveným na "none", aby nebyl citlivý na diakritiku, a poté provést $textové vyhledávání následovně:

db.Project.createIndex(
    {
        "WORKER": "text",
        "TRABAJADOR": "text"
    },
    {
        "background": false,
        "default_language": "none"
    }
)
db.Project.find({
    "$text": {
        "$search": "jesus",
        "$caseSensitive": false
    }
})

zde je kód c#, který vygeneroval výše uvedené dotazy. Pro stručnost používám svou knihovnu MongoDB.Entities.

using MongoDB.Entities;
using System;
using System.Linq;

namespace StackOverflow
{
    public class Program
    {
        public class Project : Entity
        {
            public string WORKER { get; set; }
            public string TRABAJADOR { get; set; }
        }

        private static void Main(string[] args)
        {
            new DB("test");

            DB.Index<Project>()
              .Key(p => p.WORKER, KeyType.Text)
              .Key(p => p.TRABAJADOR, KeyType.Text)
              .Option(o => o.DefaultLanguage = "none")
              .Option(o => o.Background = false)
              .Create();

            (new[] {
                new Project { WORKER = "JESUS HERNANDEZ DIAZ"},
                new Project { TRABAJADOR = "JESÚS HERNÁNDEZ DÍAZ"}
            }).Save();

            var result = DB.SearchText<Project>("jesus");

            Console.WriteLine($"found: {result.Count()}");
            Console.Read();
        }
    }
}


  1. MongoDB:dotaz na pole

  2. Získejte pouze zadané pole v MongoDB s C#

  3. Jak importovat data do mongoDB

  4. Dotaz na podobné pole v MongoDB