小编Fre*_*ken的帖子

mongodb $regex 中排序规则的使用

由于 v3.4 排序规则可用于查找操作,尤其是在关注变音符号的匹配时。虽然具有确定值($eq opeartor 或相应构造)的查找查询将匹配字母和对应的变音符号,但如果使用 $regex 来实现对部分搜索字符串(“LIKE”)的匹配,则情况并非如此)。

是否可以让 $regex 查询以与 $eq 查询相同的方式使用排序规则?

考虑示例集合 testcoll:

{ "_id" : ObjectId("586b7a0163aff45945462bea"), "city" : "Antwerpen" }, 
{ "_id" : ObjectId("586b7a0663aff45945462beb"), "city" : "Antwërpen" }
Run Code Online (Sandbox Code Playgroud)

此查询将找到两条记录

db.testcoll.find({city: 'antwerpen'}).collation({"locale" : "en_US", "strength" : 1});
Run Code Online (Sandbox Code Playgroud)

使用正则表达式的相同查询不会(仅查找带有“Antwerpen”的记录)

db.testcoll.find({city: /antwe/i}).collation({"locale" : "en_US", "strength" : 1});
Run Code Online (Sandbox Code Playgroud)

mongodb mongodb-query

6
推荐指数
2
解决办法
1970
查看次数

标签 统计

mongodb ×1

mongodb-query ×1