MONGODB关于通过排序规则设置规避大小写区分

排序规则参数

{
   locale: <string>,
   caseLevel: <boolean>,
   caseFirst: <string>,
   strength: <int>,
   numericOrdering: <boolean>,
   alternate: <string>,
   maxVariable: <string>,
   backwards: <boolean>
}

新建集合:

db.createCollection('workjsoninfo13',

                              {collation:{            //排序规则设置

                                        locale:"zh",  //区域为中文区域(必须设置)

                                       strength:2}    //比较级别为二级,不比较大小写和字符变体(默认为三级,比较大小写)

                              });

同一操作中,只支持一种排序规则,默认继承集合的排序规则。

因此新增索引时不需要调整规则,索引会继承集合的排序规则

示例:


db.createCollection('workjsoninfo12', {collation:{locale:"zh",strength:2}});

db.workjsoninfo12.insert(
[{WorkOrderId:"WI000001"},
{WorkOrderId:"wi000001"},
{WorkOrderId:"wi000004"},
{WorkOrderId:"WI000005"}]
)


db.getCollection('workjsoninfo12').createIndex({"WorkOrderId":1},{"name":"NON_WorkOrderId"});

db.workjsoninfo12.find({WorkOrderId:"WI000001"}).explain();

执行计划中,排序规则为中文、2级比较级别,命中索引。

查询结果不再区分大小写。

附参考网站:校对_MonogDB 中文网

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值