【MongoDB实战】Java中如何对MongoDB字符串数值进行排序
2021/12/17 2:10:36
本文主要是介绍【MongoDB实战】Java中如何对MongoDB字符串数值进行排序,对大家解决编程问题具有一定的参考价值,需要的程序猿们随着小编来一起学习吧!
【辰兮要努力】:hello你好我是辰兮,很高兴你能来阅读,昵称是希望自己能不断精进,向着优秀程序员前行!
博客来源于项目以及编程中遇到的问题总结,偶尔会有读书分享,我会陆续更新Java前端、后台、数据库、项目案例等相关知识点总结,感谢你的阅读和关注,希望我的博客能帮助到更多的人,分享获取新知,大家一起进步!
吾等采石之人,应怀大教堂之心,愿我们奔赴在各自的热爱里…
业务场景
最近开发涉及到字符串数值的排序问题,发现按常规写法无法进行合理排序
比如数据库对应字段涉及到金钱的相关属性存储的值,案例如下
案例一: "11.11" "13.32" "12.23"
案例二: "11.11 CNY" "13.32 CNY" "12.23 CNY"
如上案例,我们发现部分数据除了数值外,还有部分英文标识符如“CNY”人民币(RenMinBi Yuan)
实际需求:我们只想根据具体的数值排序
如期待排序结果: "11.11 CNY" "12.23 CNY" "13.32 CNY"
MongoDB查询语句
重新设置默认的collation属性.collation({“locale”: “zh”, numericOrdering:true})再排序。
语句如下:
db.getCollection(集合名称).find({}).collation({"locale": "zh", numericOrdering:true}).sort({"realTimeConsume":-1});
如上即可解决字符串数字相关排序问题
Java代码解决
在查询语句前新增如下代码即可解决
Query query = new Query(); Document source = new Document(); source.put("locale", "zh"); source.put("numericOrdering", true); Collation collation = Collation.from(source); query.collation(collation);
当使用collation时,字段locale必须要有值。
numericOrdering决定字符串是否按照数值来排序,默认为false;
运行效果
很明显发现新增如上代码后,传入对应查询条件后,页面按我们想要的数值进行排序
非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞
这篇关于【MongoDB实战】Java中如何对MongoDB字符串数值进行排序的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2025-01-10百万架构师第十三课:源码分析:Spring 源码分析:Spring核心IOC容器及依赖注入原理|JavaGuide
- 2025-01-10便捷好用的电商API工具合集
- 2025-01-09必试!帮 J 人团队解决物流错发漏发的软件神器!
- 2025-01-09不容小觑!助力 J 人物流客服安抚情绪的软件!
- 2025-01-09为什么医疗团队协作离不开智能文档工具?
- 2025-01-09惊叹:J 人团队用啥软件让物流服务快又准?
- 2025-01-09如何利用数据分析工具优化项目资源分配?4种工具推荐
- 2025-01-09多学科协作难?这款文档工具可以帮你省心省力
- 2025-01-09团队中的技术项目经理TPM:工作内容与资源优化策略
- 2025-01-09JIT生产管理法:优化流程,提升竞争力的秘诀