sql >> Database teknologi >  >> NoSQL >> MongoDB

MongoDB:Ufølsom mellem store og små bogstaver og accentufølsom

Jeg anbefaler, at du opretter et tekstindeks med standardsproget sat til "ingen" for at gøre det diakritisk ufølsomt og derefter foretager en $tekst-søgning som følger:

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

her er c#-koden, der genererede ovenstående forespørgsler. jeg bruger mit bibliotek MongoDB.Entities for kortheds skyld.

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. mongorestore ufanget undtagelse:syntaksfejl

  2. Mongodb Aggregation Group efter logisk eller?

  3. BsonValue og brugerdefinerede klasser i MongoDB C# Driver

  4. Deaktiveringsoperation mislykkedes for MongoMapper-modellen, kan ikke slette/fjerne nøgle fra modellen