MongoDB聚合运算符:$indexOfBytes

文章目录

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

语法

js 复制代码
{ $indexOfBytes: [ <string expression>, <substring expression>, <start>, <end> ] }

参数说明:

参数 说明
<string expression> 字符串表达式,如果表达式的值为null或应用的字段缺失,则返回null;如果表达式的值不为字符串、null、或字段缺失,则报错
<substring expression> 要搜索的字符串,可以是任何可解析为字符串的表达式
<start> 可选参数,可解析为大于等于零的整数的表达式,用于指定从什么位置开始搜索
<end> 可选参数,可解析为大于等于零的整数的表达式,用于指定搜索的停止位置;如果指定的<end>则必须同时指定<start>

使用

  • 如果<string expressionnull$indexOfBytes返回null
  • 如果$indexOfBytes引用的字段在文档中不存在,则$indexOfBytes返回null
  • 如果<string expression>不是字符串且不为null,则$indexOfBytes返回错误
  • 如果<substring expression>null$indexOfBytes返回错误
  • 如果<start><end>为负数,$indexOfBytes返回错误
  • 如果<start>为大于<end>的数值,$indexOfBytes返回-1
  • 如果<start>大于字符串的字节长度,则$indexOfBytes返回-1
  • 如果<start><end>的值不是整数,$indexOfBytesf返回错误
  • 如果<substring expression><string expression中多次出现,$indexOfBytes返回第一次发现的位置。

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

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

举例

inventory集合有下列数据:

json 复制代码
{ "_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 }

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

js 复制代码
db.inventory.aggregate(
   [
     {
       $project:
          {
            byteLocation: { $indexOfBytes: [ "$item", "foo" ] },
          }
      }
   ]
)

操作的结果如下:

json 复制代码
{ "_id" : 1, "byteLocation" : "0" }
{ "_id" : 2, "byteLocation" : "4" }
{ "_id" : 3, "byteLocation" : "4" }
{ "_id" : 4, "byteLocation" : "-1" }
{ "_id" : 5, "byteLocation" : null }
{ "_id" : 6, "byteLocation" : null }
相关推荐
春风霓裳5 小时前
sql-窗口函数
大数据·数据库·sql
言之。6 小时前
【数据库】TiDB 技术选型与架构分析报告
数据库·架构·tidb
人工智能训练6 小时前
如何在 Ubuntu 22.04 中安装 Docker 引擎和 Linux 版 Docker Desktop 桌面软件
linux·运维·服务器·数据库·ubuntu·docker·ai编程
胖头鱼的鱼缸(尹海文)6 小时前
数据库管理-第386期 使用OCP部署OceanBase 4.4.1社区版集群(20251107)
数据库·oceanbase
Craaaayon6 小时前
如何选择两种缓存更新策略(写缓存+异步写库;写数据库+异步更新缓存)
java·数据库·redis·后端·缓存·mybatis
一 乐7 小时前
点餐|智能点餐系统|基于java+ Springboot的动端的点餐系统小程序(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·小程序·论文
WarriorTan7 小时前
理解PostgreSQL中的数据块
数据库·postgresql
学好statistics和DS7 小时前
三个好思路:SQL并行化处理、混淆矩阵和特征交叉
数据库·sql·矩阵
唐僧洗头爱飘柔95277 小时前
【GORM(3)】Go的跨时代ORM框架!—— 数据库连接、配置参数;本文从0开始教会如何配置GORM的数据库
开发语言·数据库·后端·golang·gorm·orm框架·dsn
谅望者8 小时前
在 macOS 上使用 Homebrew 安装 MySQL 8.0 完整指南
数据库·sql·mysql