sql >> Databasteknik >  >> NoSQL >> MongoDB

MongoDB:Skiftlägesokänslig och accentokänslig

Jag rekommenderar att du skapar ett textindex med standardspråket inställt på "ingen" för att göra det diakritiskt okänsligt och sedan gör en $text-sökning enligt följande:

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

här är c#-koden som genererade ovanstående frågor. Jag använder mitt bibliotek MongoDB.Entities för korthetens skull.

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. Node Mongo REST Service Post

  2. Jämföra MongoDB-prestanda på offentliga moln:AWS, Azure och DigitalOcean

  3. Varför är $in mycket snabbare än $all?

  4. Hur sparar man en mängd objekt till mongoose DB med bara ett anrop?