MongoDB聚合运算符:$toString

MongoDB聚合运算符:$toString


$toString聚合运算符将指定的值转换为字符串类型。如果指定的值为空或缺失,则返回null;如果值无法被转换为字符串,则报错。

语法

{
   $toString: <expression>
}

$toString接受任何有效的表达式。

$toString$convert表达式的简写形式:

{ $convert: { input: <expression>, to: "string" } }

使用

下表列出了可转换为字符串的类型:

输入类型 规则
Boolean 返回布尔值的字符串
Decimal 返回小数值的字符串
Double 返回双精度数的字符串
Integer 返回整数的字符串
Long 返回长整数的字符串
String 直接返回
ObjectId 返回ObjectId值的16进制字符串
Date 返回日期字符串

下表列出了一些转换为字符串的示例:

示例 结果
$toString: true "true"
$toString: false "false"
$toString: 2.5 "2.5"
$toString: NumberInt(2) "2"
$toString: NumberLong(1000) "1000"
$toString: NumberInt(8) Long(8)
$toString: ObjectId("5ab9c3da31c2ab715d421285") "5ab9c3da31c2ab715d421285"
$toString: ISODate("2018-03-27T16:58:51.538Z" "2018-03-27T16:58:51.538Z"

举例

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

db.orders.insertMany( [
   { _id: 1, item: "apple",  qty: 5, zipcode: 93445 },
   { _id: 2, item: "almonds", qty: 2, zipcode: "12345-0030" },
   { _id: 3, item: "peaches",  qty: 5, zipcode: 12345 },
] )

下面的聚合操将zipcode集转换为字符串,然后进行排序:

// 定义阶段,将zipcode转换为字符串

zipConversionStage = {
   $addFields: {
      convertedZipCode: { $toString: "$zipcode" }
   }
};

// 定义阶段,基于转换后的字段convertedZipCode进行排序

sortStage = {
   $sort: { "convertedZipCode": 1 }
};


db.orders.aggregate( [
  zipConversionStage,
  sortStage
] )

执行的结果为:

{
  _id: 3,
  item: 'peaches',
  qty: 5,
  zipcode: 12345,
  convertedZipCode: '12345'
},
{
  _id: 2,
  item: 'almonds',
  qty: 2,
  zipcode: '12345-0030',
  convertedZipCode: '12345-0030'
},
{
  _id: 1,
  item: 'apple',
  qty: 5,
  zipcode: 93445,
  convertedZipCode: '93445'
}

**注意:**如果转换操作遇到错误,聚合操作将停止并抛出错误。

相关推荐

  1. MongoDB聚合运算符:$toString

    2024-05-12 10:52:02       10 阅读
  2. MongoDB聚合运算符:$add

    2024-05-12 10:52:02       34 阅读
  3. MongoDB聚合运算符:$arrayToObject

    2024-05-12 10:52:02       28 阅读
  4. MongoDB聚合运算符;$dateToParts

    2024-05-12 10:52:02       26 阅读
  5. MongoDB聚合运算符:$dayOfWeek

    2024-05-12 10:52:02       28 阅读
  6. MongoDB聚合运算符:$dayOfMonth

    2024-05-12 10:52:02       28 阅读
  7. MongoDB聚合运算符;$dateToString

    2024-05-12 10:52:02       23 阅读
  8. MongoDB聚合运算符:$dayOfYear

    2024-05-12 10:52:02       23 阅读
  9. MongoDB聚合运算符:$denseRank

    2024-05-12 10:52:02       18 阅读
  10. MongoDB聚合运算符:$dateTrunc

    2024-05-12 10:52:02       25 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-05-12 10:52:02       19 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-12 10:52:02       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-12 10:52:02       20 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-12 10:52:02       20 阅读

热门阅读

  1. Flutter备用依赖

    2024-05-12 10:52:02       10 阅读
  2. 什么是渐进式框架

    2024-05-12 10:52:02       8 阅读
  3. matlab人脸识别

    2024-05-12 10:52:02       8 阅读
  4. 基于STM32的衣柜防潮系统设计的毕业论文

    2024-05-12 10:52:02       8 阅读
  5. Android中C++如何读写json文件

    2024-05-12 10:52:02       12 阅读
  6. 跟我学C++中级篇——内联补遗

    2024-05-12 10:52:02       14 阅读
  7. oracle 递归查询(结构树)

    2024-05-12 10:52:02       12 阅读
  8. Dijkstra算法

    2024-05-12 10:52:02       8 阅读
  9. 目标检测 yolov8 pth ==> onnx

    2024-05-12 10:52:02       8 阅读
  10. mongoDB

    mongoDB

    2024-05-12 10:52:02      12 阅读
  11. 麒麟系统+飞腾处理器 qt5.9.0 编译安装教程

    2024-05-12 10:52:02       10 阅读
  12. sqlite3报错:database is locked

    2024-05-12 10:52:02       12 阅读