MongoDB数字字符串排序问题

问题描述

MongoDB中有一个集合t_test_sort结构如下,其中数值字段value为字符串类型,现想按照value的数值大小进行降序排列。

css 复制代码
{
    "_id" : ObjectId("656c87b36ca8100cd4a60348"),
    "name" : "麻了",
    "date" : "2033-04-05",
    "value" : "-1.744353",
    "_class" : "com.rkyao.spring.boot.mongo.entity.MongoSortEntity"
}

使用如下查询语句进行查询,得到的结果显然不对,这样是按照字符串进行排的,而不是数值大小

lua 复制代码
db.getCollection("t_test_sort")
    .find({})
    .sort({ "value": -1 })

尝试解决

网上搜索了一波解决方案都是要添加numericOrdering:true配置,这样可以将字符串按照数值排序,但是试验后依然不行。

lua 复制代码
db.getCollection("t_test_sort")
    .find({})
    .sort({ "value": -1 })
    .collation({"locale": "zh",numericOrdering:true})

百思不得其姐,查询MongoDB官方文档后找到了原因,原来是numericOrdering:true只支持非负整数,负数和小数都不支持

网上的方案行不通,只能继续研究了。

解决方案

方案一

value字段的类型修改为数值型,但是修改字段的影响比较大,需要重新刷数据且有可能会影响其他业务,所以除非走投无路暂不考虑。

方案二

再次查询官方文档后找到了一个方法,可以在聚合管道中使用$toDecimalvalue字段的值转换为数值,赋给一个临时字段sortField,然后在根据sortField字段进行排序。

php 复制代码
db.getCollection("t_test_sort").aggregate([
    {
        $addFields: {
            sortField: { $toDecimal: "$value" }
        }
    },
    {
        $sort: { sortField: -1 }
    }
])

可以看到查询结果完全按照sortField数值大小降序排列,问题解决。

Java代码也一并给出来

csharp 复制代码
public List<MongoSortEntity> sort() {
        List<AggregationOperation> operationList = new ArrayList<>();
        operationList.add(
                Aggregation.project("_id", "name", "date", "value")
                        .and(ConvertOperators.ToDecimal.toDecimal("$value")).as("sortField")
        );
        operationList.add(Aggregation.sort(Sort.by(Sort.Direction.DESC, "sortField")));
        Aggregation aggregation = Aggregation.newAggregation(operationList);
        AggregationResults<MongoSortEntity> results = mongoTemplate.aggregate(aggregation, 't_test_sort', MongoSortEntity.class);
        return results.getMappedResults();
    }

参考文档

numericOrdering用法

www.mongodb.com/docs/manual...

$toDecimal用法

www.mongodb.com/docs/manual...

相关推荐
AI全栈实验室6 天前
MongoDB迁移金仓踩了5个坑,最后一个差点回滚
mongodb
数据知道7 天前
MongoDB 元素查询运算符:使用 `$exists` 检查字段是否存在及处理缺失字段
数据库·mongodb
数据知道7 天前
MongoDB 批量写操作:`bulkWrite()` 在数据迁移与清洗中的高性能应用
数据库·mongodb
数据知道7 天前
MongoDB 数组更新操作符:`$push`、`$pull`、`$addToSet` 管理列表数据
数据库·mongodb
数据知道7 天前
MongoDB 更新操作符 `$set` 与 `$unset`:精准修改字段与删除字段
数据库·mongodb
数据知道7 天前
MongoDB 数值更新原子操作:`$inc` 实现点赞、计数器等高并发原子操作
数据库·算法·mongodb
数据知道8 天前
MongoDB 数组查询专项:`$all`、`$elemMatch` 与精确匹配数组的使用场景
数据库·mongodb
数据知道8 天前
MongoDB 正则表达式查询:在 MongoDB 中实现模糊搜索与索引优化陷阱
数据库·mongodb·正则表达式
正在走向自律8 天前
文档数据库替换新范式:金仓数据库MongoDB兼容性深度解析与实践指南
数据库·mongodb·国产数据库·金仓数据库
I'mAlex9 天前
金仓数据库平替MongoDB实操解析:多模融合赋能企业文档数据管理国产化升级
数据库·mongodb·kingbasees·金仓数据库