MongoDB聚合运算符:$toDouble

MongoDB聚合运算符:$toDouble

文章目录

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

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

语法

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

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

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

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

使用

下表列出了可转换为布尔值的类型:

输入类型 规则
Boolean 对于True,返回1,对于False返回0
Decimal 以Double返回Decimal的值,Decimal的值必须在Double的范围内,超出Double值域范围的Decimal不能转换
Double 原样返回
Integer 以Double返回整数值
Long 以Double返回Long值
String 将字符串转换为Double返回,但字符串表示的必须是10进制的比如"-5.5"、"1233",非10进制的会报错,如:"0x3343"
Date 返回自与日期值对应的纪元以来的毫秒数

下表列出了一些转换为布尔值的示例:

示例 结果
{$toDouble: true} 1
{$toDouble: false} 0
{$toDouble: 2.5} 2.5
{$toDouble: NumberInt(5)} 5
{$toDouble: NumberLong(10000)} 10000
{$toDouble: "-5.5"} -5.5
{$toDouble: ISODate("2018-03-27T05:04:47.890Z")} 1522127087890

举例

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

js 复制代码
db.weather.insertMany( [
   { _id: 1, date: new Date("2018-06-01"), temp: "26.1C" },
   { _id: 2,  date: new Date("2018-06-02"), temp: "25.1C" },
   { _id: 3,  date: new Date("2018-06-03"), temp: "25.4C" },
] )

下面的聚合操将weather集合的temp值转换为Double:

js 复制代码
//将转换后的字段添加到文档

// Define stage to add degrees field with converted value

tempConversionStage = {
   $addFields: {
      degrees: { $toDouble: { $substrBytes: [ "$temp", 0, 4 ] } }
   }
};


db.weather.aggregate( [
   tempConversionStage,
] )

执行的结果为:

json 复制代码
{ "_id" : 1, "date" : ISODate("2018-06-01T00:00:00Z"), "temp" : "26.1C", "degrees" : 26.1 }
{ "_id" : 2, "date" : ISODate("2018-06-02T00:00:00Z"), "temp" : "25.1C", "degrees" : 25.1 }
{ "_id" : 3, "date" : ISODate("2018-06-03T00:00:00Z"), "temp" : "25.4C", "degrees" : 25.4 }
相关推荐
m0_748554815 小时前
golang如何实现用户订阅偏好管理_golang用户订阅偏好管理实现总结
jvm·数据库·python
早日退休!!!6 小时前
《数据结构选型指南》笔记
数据结构·数据库·oracle
xcLeigh6 小时前
KES数据库性能优化实战
数据库·sql·性能优化·sql优化·数据性能
阿正呀6 小时前
Redis怎样实现本地缓存的高效失效通知
jvm·数据库·python
yoyo_zzm6 小时前
Laravel9.x新特性全解析
数据库·mysql·nginx
2501_901200536 小时前
mysql如何设置InnoDB引擎参数_优化innodb_buffer_pool
jvm·数据库·python
m0_495496417 小时前
mysql处理复杂SQL性能_InnoDB优化器与MyISAM差异
jvm·数据库·python
forEverPlume8 小时前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
2301_809204708 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
虹科网络安全8 小时前
艾体宝产品|深度解读 Redis 8.4 新增功能:原子化 Slot 迁移(上)
数据库·redis·bootstrap