ICode9

精准搜索请尝试: 精确搜索
首页 > 数据库> 文章详细

【MongoDB实战】Java中如何对MongoDB字符串数值进行排序

2021-12-16 23:03:09  阅读:201  来源: 互联网

标签:Java locale MongoDB CNY source collation 排序 numericOrdering


【辰兮要努力】: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;


运行效果

很明显发现新增如上代码后,传入对应查询条件后,页面按我们想要的数值进行排序

在这里插入图片描述


非常感谢你阅读到这里,如果这篇文章对你有帮助,希望能留下你的点赞

标签:Java,locale,MongoDB,CNY,source,collation,排序,numericOrdering
来源: https://blog.csdn.net/weixin_45393094/article/details/121985730

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有