sql >> Database >  >> NoSQL >> MongoDB

MongoDB:niet-hoofdlettergevoelig en accentongevoelig

ik raad u aan een tekstindex te maken met de standaardtaal ingesteld op "none" om het diakritisch ongevoelig te maken en vervolgens een $text-zoekopdracht als volgt uit te voeren:

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

hier is de c#-code die de bovenstaande query's heeft gegenereerd. ik gebruik mijn bibliotheek MongoDB.Entities voor de beknoptheid.

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. Lezen van Kinesis geeft lege records wanneer het wordt uitgevoerd met het vorige volgnummer of tijdstempel

  2. De DevOps Open Source Database Audit Manual - Alles wat u moet weten

  3. Waarom retourneert Laravel Redis::scan('*') een verwachte sleutel, maar Redis::keys('*') niet?

  4. Java-stuurprogramma-equivalent voor Object.bsonsize (doc) van JavaScript-shell?