MongoDB聚合运算符:$toString

MongoDB聚合运算符:$toString

文章目录

  • [MongoDB聚合运算符:toString](#MongoDB聚合运算符:toString)

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

语法

js 复制代码
{
   $toString: <expression>
}

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

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

js 复制代码
{ $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集合:

js 复制代码
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集转换为字符串,然后进行排序:

js 复制代码
// 定义阶段,将zipcode转换为字符串

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

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

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


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

执行的结果为:

js 复制代码
{
  _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'
}

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

相关推荐
小李学不完23 分钟前
Oracle--SQL事务操作与管理流程
数据库
qq_4419960525 分钟前
为何 RAG 向量存储应优先考虑 PostgreSQL + pgvector 而非 MySQL?
数据库·mysql·postgresql
Ivan陈哈哈33 分钟前
Redis是单线程的,如何提高多核CPU的利用率?
数据库·redis·缓存
小光学长1 小时前
基于vue框架的电信用户业务管理系统的设计与实现8ly70(程序+源码+数据库+调试部署+开发环境)带论文文档1万字以上,文末可获取,系统界面在最后面。
数据库
程序员不想YY啊2 小时前
MySQL元数据库完全指南:探秘数据背后的数据
数据库·mysql·oracle
数据最前线2 小时前
Doris表设计与分区策略:让海量数据管理更高效
数据库
时光追逐者2 小时前
MongoDB从入门到实战之MongoDB快速入门(附带学习路线图)
数据库·学习·mongodb
头顶秃成一缕光2 小时前
Redis的主从模式和哨兵模式
数据库·redis·缓存
AIGC大时代2 小时前
高效使用DeepSeek对“情境+ 对象 +问题“型课题进行开题!
数据库·人工智能·算法·aigc·智能写作·deepseek
博睿谷IT99_2 小时前
数据库证书可以选OCP认证吗?
数据库·oracle·开闭原则·ocp认证