MongoDB聚合运算符:$trunc
$trunc聚合运算符用于将数字截断为整数或指定的小数位。
语法
{
$trunc : [ <number>, <place> ] }
参数字段
<numer>:数值类型,可以是任何能够解析为数值的表达式,比如是整数、双精度数、小数或长整数。如果解析为非表达式,则返回错误。<place>:整数,可选字段,可以是任何可被解析为整数的表达式,必须在-20到100之间,也就是:-20< place < 100,如果不指定,缺省值为0。- 如果
<place>被解析为正整数,$trunc四舍五入到<place>小数位。如:$trunc: [1234.5678, 2]保留两位小数,返回1234.56。 - 如果
<place>解析为一个负整数,$trunc使用小数点左边的数字<place>进行截取。例如$trunc : [1234.5678, -2]应用到小数点左边的第二位数字 (3) 并返回1200。如果<place>的绝对值等于或超过小数点左边的位数,则$trunc返回0。例如:$trunc : [ 1234.5678, -5]指定到了小数位左边的第5位,大于小数点左边的数字位数,所以返回0。 - 如果
<place>解析为0,$trunc对小数位右边第一位数字进行截取,返回整数部分。如:$trunc : [1234.5678, 0]返回1234。
- 如果
使用
$trunc不会对截断的数据进行舍入。要将输入值舍入到指定位置,可使用 $round表达式。
返回的数据类型
如果截断到特定的小数位,$trunc返回的数据类型与输入表达式或值的数据类型一致,如果截断到整数位,$trunc返回整数。
null, NaN, 和 正/负无穷
- 如果第一个参数解析为
null值或引用缺少的字段,则$trunc返回null。 - 如果第一个参数解析为
NaN,则$trunc返回NaN。 - 如果第一个参数解析为负无穷大或正无穷大,则
$trunc分别返回负无穷大或正无穷大。
|例子|结果|
|=|-|
|{ $trunc: [ NaN, 1] }|NaN|
|{ $trunc: [ null, 1] }|null|
|{ $trunc : [ Infinity, 1 ] }|Infinity|
|{ $trunc : [ -Infinity, 1 ] }|-Infinity|
举例
使用下面脚本创建samples集合:
db.samples.insertMany(
[
{

最低0.47元/天 解锁文章
2015

被折叠的 条评论
为什么被折叠?



