由于 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)