Docs 菜单

Docs 主页开发应用程序MongoDB Manual

$strLenCP(聚合)

在此页面上

  • 定义
  • 行为
  • 例子
$strLenCP

返回 UTF-8 代码点数 在指定字符串中。

$strLenCP采用以下操作符表达式语法:

{ $strLenCP: <string expression> }

该参数可以是解析为字符串的任何有效表达式

如果参数解析为null的值或引用了缺失的字段, $strLenCP将返回错误。

例子
结果
{ $strLenCP: "abcde" }
5
{ $strLenCP: "Hello World!" }
12
{ $strLenCP: "cafeteria" }
9
{ $strLenCP: "cafétéria" }
9
{ $strLenCP: "" }
0
{ $strLenCP: "$€λA" }
4
{ $strLenCP: "寿司" }
2

$strLenCP操作符计算指定字符串中的代码点数。此行为不同于计算字符串中字节数的$strLenBytes操作符,其中每个字符使用 1 到 4 个字节。

创建一个 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 值的 length

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 }
]

提示

另请参阅:

← $strLenBytes(聚合)

在此页面上