MongoDB聚合运算符:$strLenCP

embedded/2024/10/20 3:43:55/

MongoDB聚合运算符:$strLenCP

$strLenCP聚合运算符返回指定字符串中 UTF-8 代码点的数量。

语法

{ $strLenCP: <string expression> }

<expression>为可解析为字符串的表达式,如果解析为null或引用了不存在的字段,返回错误。

使用

$strLenCP 运算符计算指定字符串中的代码点数量,这不同于 $strLenBytes 运算符,后者计算字符串中的字节数,其中每个字符使用 1 到 4 个字节。

返回
{ $strLenCP: "abcde" }5
{ $strLenCP: "Hello World!" }12
{ $strLenCP: "cafeteria" }9
{ $strLenCP: "cafétéria" }9
{ $strLenCP: "" }0
{ $strLenCP: "$€λG" }4
{ $strLenCP: "寿司" }2

举例

单字节和多字节字符集

使用下面的脚本创建food集合:

db.food.insertMany([{ "_id" : 1, "name" : "apple" },{ "_id" : 2, "name" : "banana" },{ "_id" : 3, "name" : "éclair" },{ "_id" : 4, "name" : "hamburger" },{ "_id" : 5, "name" : "jalapeño" },{ "_id" : 6, "name" : "pizza" },{ "_id" : 7, "name" : "tacos" },{ "_id" : 8, "name" : "寿司" }]
)

下面的聚合使用 $strLenCP 运算符计算name的长度:

db.food.aggregate( [{$project: {name: 1,length: { $strLenCP: "$name" }}}
] )

操作返回下面的结果:

[{ _id: 1, name: 'apple', length: 5 },{ _id: 2, name: 'banana', length: 6 },{ _id: 3, name: 'éclair', length: 6 },{ _id: 4, name: 'hamburger', length: 9 },{ _id: 5, name: 'jalapeño', length: 8 },{ _id: 6, name: 'pizza', length: 5 },{ _id: 7, name: 'tacos', length: 5 },{ _id: 8, name: '寿司', length: 2 }
]

http://www.ppmy.cn/embedded/26327.html

相关文章

Centos7+Hadoop3.3.4+KDC1.15+Ranger2.4.0集成

一、集群规划 本次测试采用3台虚拟机&#xff0c;操作系统版本为centos7.6。 kerberos采用默认YUM源安装&#xff0c;版本为&#xff1a;1.15.1-55 Ranger版本为2.4.0 系统用户为ranger:ranger IP地址主机名KDCRanger192.168.121.101node101.cc.localKDC masterRanger Admin…

【数据结构】位图与布隆过滤器

目录 前言 位图的概念 经典面试题目 位图的模拟实现 set() reset() test() 位图整体代码 位图的应用 位图的优缺点 布隆过滤器 布隆过滤器的概念 哈希函数的个数与布隆过滤器长度的关系 布隆过滤器的模拟实现 插入 查找 删除 布隆过滤器整体代码 前言 哈希本质…

01-DispatchServlet和RequestMapping

SpringMVC启动 server.port8090 spring.mvc.servlet.load-on-startup1Configuration ComponentScan // 引入配置 PropertySource("classpath:application.properties") EnableConfigurationProperties({ServerProperties.class, WebMvcProperties.class}) public c…

设计模式(十一):外观模式

设计模式&#xff08;十一&#xff09;&#xff1a;外观模式 1. 外观模式的介绍2. 外观模式的类图3. 外观模式的实现3.1 创建一个接口3.2 创建接口的实现3.3 创建一个外观类3.4 测试 1. 外观模式的介绍 外观模式&#xff08;Facade Pattern&#xff09;属于结构型模式&#xf…

RocketMQ与Kafka深度对比:消息中间件的选择之战

引言 在当今日益复杂和高速的信息化时代&#xff0c;消息中间件已成为构建高可用、高扩展性系统的核心组件之一。它们为分布式系统提供了异步通信机制&#xff0c;允许各个微服务、组件或应用程序之间以可靠和高效的方式进行数据交换。简单来说&#xff0c;消息中间件就像是企…

vscode 检查更新 没有检查更新按钮

vscode 检查更新 没有检查更新按钮 1、问题描述2、问题分析3、解决方法 1、问题描述 今天在使用vscode写markdown文档时&#xff0c;需要粘贴图片到markdown文档中&#xff0c;结果无法粘贴进来&#xff0c;显示如下&#xff1a;只粘贴了image.png这几个字。 2、问题分析 搜索…

外包干了2个月,技术退步明显。。。。。

先说一下自己的情况&#xff0c;本科生&#xff0c;17年通过校招进入武汉某软件公司&#xff0c;干了接近3年的功能测试&#xff0c;今年五一&#xff0c;感觉自己不能够在这样下去了&#xff0c;长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了3年的功能测试&…

【DevOps入门到精通】导读:探索软件开发与运维的协同之道

目录 DevOps简介 专栏结构概览 第一部分&#xff1a;入门阶段 DevOps概述 核心实践 工具与环境 第二部分&#xff1a;提高阶段 深入CI/CD 自动化测试进阶 监控与日志 第三部分&#xff1a;精通阶段 容器化与微服务架构 DevSecOps 高级监控与优化 第四部分&#…