MongoDB聚合运算符:$strLenCP

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

相关推荐

  1. MongoDB聚合运算符:$strLenCP

    2024-05-01 07:18:02       34 阅读
  2. MongoDB聚合运算符:$add

    2024-05-01 07:18:02       55 阅读
  3. MongoDB聚合运算符:$arrayToObject

    2024-05-01 07:18:02       53 阅读
  4. MongoDB聚合运算符;$dateToParts

    2024-05-01 07:18:02       53 阅读
  5. MongoDB聚合运算符:$dayOfWeek

    2024-05-01 07:18:02       55 阅读
  6. MongoDB聚合运算符:$dayOfMonth

    2024-05-01 07:18:02       52 阅读
  7. MongoDB聚合运算符;$dateToString

    2024-05-01 07:18:02       48 阅读
  8. MongoDB聚合运算符:$dayOfYear

    2024-05-01 07:18:02       48 阅读
  9. MongoDB聚合运算符:$denseRank

    2024-05-01 07:18:02       42 阅读
  10. MongoDB聚合运算符:$dateTrunc

    2024-05-01 07:18:02       46 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-05-01 07:18:02       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-05-01 07:18:02       106 阅读
  3. 在Django里面运行非项目文件

    2024-05-01 07:18:02       87 阅读
  4. Python语言-面向对象

    2024-05-01 07:18:02       96 阅读

热门阅读

  1. Scala 重难点总结

    2024-05-01 07:18:02       38 阅读
  2. link和@import的区别

    2024-05-01 07:18:02       31 阅读
  3. iOS cocoapods 升级

    2024-05-01 07:18:02       33 阅读
  4. scala基础学习--变量,标识符,类型和类型转换

    2024-05-01 07:18:02       42 阅读
  5. redis多用户管理

    2024-05-01 07:18:02       35 阅读
  6. Docker 快速入门

    2024-05-01 07:18:02       33 阅读
  7. Oracle 存过 与Postgresql 的存过的差别

    2024-05-01 07:18:02       34 阅读
  8. 第六十七章 使用 NSD (UNIX® Linux macOS)

    2024-05-01 07:18:02       32 阅读
  9. 9、Flink 用户自定义 Functions 及 累加器详解

    2024-05-01 07:18:02       30 阅读
  10. 个人对行为型设计模式的理解 @by_TWJ

    2024-05-01 07:18:02       27 阅读
  11. Ubuntu中访问windows中的共享文件夹

    2024-05-01 07:18:02       35 阅读
  12. Vue3 + Element-plus 报错 require is not defined 处理问题

    2024-05-01 07:18:02       30 阅读
  13. 香港BGP服务器和香港双线服务器的区别

    2024-05-01 07:18:02       37 阅读