MongoDB聚合运算符:$indexOfCP

文章目录

$indexOfCP聚合运算符使用UTF-8代码点搜索字符串中出现的子字符串第一次出现的位置(从零开始)。如果未找到子字符串,则返回 -1。

语法

{ $indexOfCP: [ <string expression>, <substring expression>, <start>, <end> ] }

$indexOfCP参数说明:

字段类型是否必须说明
<string>字符串能够解析为字符串的表达式,如果表达式的值为null或引用的字段缺失,$indexOfCP返回null;如果表达式结果为非字符串或null且引用字段都存在,$indexOfCP返回错误
<substring>字符串能够解析为字符串的表达式
<start>整数大于等于零的整数或能转换为整数的数值(如:2.0)表达式,如果不指定则从开始搜索
<end>整数大于等于零的整数或能转换为整数的数值(如:2.0)表达式。如果指定的<end>则应该也要指定<start>否则<end>就会被当做<start>,如果不指定则搜索到最后

使用

  • 如果<substring string><string expression>中出现多次,返回第一次出现的位置。
  • 下面的情况$indexOfCP返回null
    • <string expression>null
    • <string expression引用的字段不存在
  • 下面的情况$indexOfCP返回错误:
    • <string expresion>不为空且值不是字符串
    • <substring expression>为空或不是字符串或引用不存在的字段
    • <start><end>为负数
  • 下面的情况$indexOfCP返回-1
    • <string expression>中不包含<substring expression>
    • <start>大于<end>
    • <start>大于字符串的字节长度

下面是一些例子来说明典型的规则:

举例结果
{ $indexOfCP: [ "cafeteria", "e" ] }3
{ $indexOfCP: [ "cafétéria", "é" ] }3
{ $indexOfCP: [ "cafétéria", "e" ] }-1
{ $indexOfCP: [ "cafétéria", "t" ] }4
{ $indexOfCP: [ "foo.bar.fi", ".", 5 ] }7
{ $indexOfCP: [ "vanilla", "ll", 0, 2 ] }-1
{ $indexOfCP: [ "vanilla", "ll", -1 ] }Error
{ $indexOfCP: [ "vanilla", "ll", 12 ] }-1
{ $indexOfCP: [ "vanilla", "ll", 5, 2 ] }-1
{ $indexOfCP: [ "vanilla", "nilla", 3 ] }-1
{ $indexOfCP: [ null, "foo" ] }null

举例

inventory集合有下列数据:

{ "_id" : 1, "item" : "foo" }
{ "_id" : 2, "item" : "fóofoo" }
{ "_id" : 3, "item" : "the foo bar" }
{ "_id" : 4, "item" : "hello world fóo" }
{ "_id" : 5, "item" : null }
{ "_id" : 6, "amount" : 3 }

下面的聚合操作使用indexOfCP运算符来检索字符串foo在每个item中的编码点位置:

db.inventory.aggregate(
   [
     {
       $project:
          {
            cpLocation: { $indexOfCP: [ "$item", "foo" ] },
          }
      }
   ]
)

操作的结果如下:

{ "_id" : 1, "cpLocation" : "0" }
{ "_id" : 2, "cpLocation" : "3" }
{ "_id" : 3, "cpLocation" : "4" }
{ "_id" : 4, "cpLocation" : "-1" }
{ "_id" : 5, "cpLocation" : null }
{ "_id" : 6, "cpLocation" : null }
  • 10
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

原子星

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值