MongoDB聚合运算符:$toInt

MongoDB聚合运算符:$toInt

文章目录

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

语法

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

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

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

js 复制代码
{ $convert: { input: <expression>, to: "int" } }

使用

下表列出了可转换为整数的类型:

输入类型 规则
Boolean 对于True,返回1,对于False返回0
Decimal 返回截断值。截断的小数值必须在整数的最小值和最大值范围内。如果截断值小于最小整数值或大于最大整数值,则无法转换
Double 返回截断值。截断的双数值必须在整数的最小值和最大值范围内。如果截断值小于最小整数值或大于最大整数值,则无法转换
Integer 直接返回
Long 以整数返回Long值,Long值必须在整数的最小值和最大值范围内。如果截断值小于最小整数值或大于最大整数值,则无法转换
String 将字符串转换为整数返回,但字符串表示的必须是10进制的整数比如"-5"、"1233",非10进制的会报错,如:"0x3343"

下表列出了一些转换为整数的示例:

示例 结果
$toInt: true 1
$toInt: false 0
$toInt: 1.99999 1
$toInt: NumberDecimal("5.5000") 5
$toInt: NumberDecimal("9223372036000.000") Error
$toInt: NumberLong("5000") 5000
$toInt: NumberLong("922337203600") Error
$toInt: "-2" -2
$toInt: "2.5" Error
$toInt: null null

举例

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

js 复制代码
db.orders.insertMany( [
   { _id: 1, item: "apple", qty: "5", price: 10 },
   { _id: 2, item: "pie", qty: "10", price: NumberDecimal("20.0") },
   { _id: 3, item: "ice cream", qty: "2", price: "4.99" },
   { _id: 4, item: "almonds" ,  qty: "5", price: 5 }
] )

下面的聚合操将qty集转换为整数,将Price转换为小数,并计算总价格:

js 复制代码
// 定义阶段,转换price为小数,转换qty为整数

priceQtyConversionStage = {
   $addFields: {
      convertedPrice: { $toDecimal: "$price" },
      convertedQty: { $toInt: "$qty" },
   }
};

// 定义阶段,计算总价


totalPriceCalculationStage = {
   $project: { item: 1, totalPrice: { $multiply: [ "$convertedPrice", "$convertedQty" ] } }
};

db.orders.aggregate( [
   priceQtyConversionStage,
   totalPriceCalculationStage
] )

执行的结果为:

js 复制代码
{ _id: 1, item: 'apple', totalPrice: Decimal128("50") },
{ _id: 2, item: 'pie', totalPrice: Decimal128("200.0") },
{ _id: 3, item: 'ice cream', totalPrice: Decimal128("9.98") },
{ _id: 4, item: 'almonds', totalPrice: Decimal128("25") }
相关推荐
喝醉酒的小白4 分钟前
数据库如何确定或计算 LSN(日志序列号)
数据库
dengjiayue10 分钟前
使用 redis 实现消息队列
数据库·redis·缓存
小羊学伽瓦13 分钟前
【Redis】——最佳实践
数据库·redis·缓存
biubiubiu070638 分钟前
Mysql
数据库·mysql
凌辰揽月1 小时前
眨眼睛查看密码工具类
java·开发语言·数据库
Arbori_262151 小时前
oracle 索引失效
数据库·oracle
StarRocks_labs2 小时前
StarRocks 助力首汽约车精细化运营
大数据·数据库·starrocks·spark·数据查询·存算分离
烧瓶里的西瓜皮3 小时前
Go语言从零构建SQL数据库(6) - sql解析器(番外)- *号的处理
数据库·sql·golang
TDengine (老段)3 小时前
TDengine.C/C++ 连接器
大数据·c语言·数据库·c++·时序数据库·tdengine·iotdb
TDengine (老段)3 小时前
TDengine 3.3.6.0 版本中非常实用的 Cols 函数
大数据·数据库·物联网·时序数据库·tdengine·iotdb