mysql - mongo如何对一个collection进行顺序上的调整呢?
问题描述
如题目所说,我这里在mongo中有一个collection,需要往里面插入一些数据,但是我想把插入的这几个数据在这个collection的前几位显示,大家有什么好的办法没?在此先谢过了
问题解答
回答1:一个 collection 里的自然顺序是由 mongodb 自己管理的,你控制不了。如果你需要按某种顺序使用数据,那就直截了当地告诉 mongodb 按什么排序。
回答2:使用mongodb的排序功能吧, 你可以在你插入的数据上取一个可以用于排序的字段升序或是降序排列,1是升,-1是降
db.coll.find({}).sort({’字段’: 1})回答3:
很遗憾你要做的事情没有办法实现。从JSON规范可以看出
An object is an unordered set of name/value pairs.
集合是无序的,所以没有办法控制显示的时候元素出现的位置。不过换个角度想想,这样的功能其实对你来说没有多大意义。
如果是在应用中,你展现给用户的顺序是你自己定义的顺序,跟本身的元素出现顺序无关;
如果在数据库中,实际上只有数据库管理员能看到,这个顺序也只对某个管理员有意义;
在我看来这不是一个很难的功能,之所以没有实现,因为没有什么实用价值,而只会拖慢数据库的速度,这就有违数据库本身的价值观了:数据库的主要目的是高效地为你提供数据,不是以不同的形式展现数据,展现数据应该是应用要关心的事情。如果你实在想看某几个值,应该通过projection来控制输出的元素而不是依赖原来的顺序。
相关文章:
1. thinkPHP5中获取数据库数据后默认选中下拉框的值,传递到后台消失不见。有图有代码,希望有人帮忙2. android - java tm platform se binary 占用很多内存3. Java中的多人游戏。将客户端(玩家)连接到其他客户端创建的游戏4. javascript - CSS图片轮播显示问题5. mysql 怎么做到update只更新一行数据?6. javascript - 项目用IE浏览器打开修改前端内容,后台数据修改了,但是前端页面内容不变,用谷歌浏览器测试前端页面可以刷新,求大神解决。7. javascript - 关于js高级程序中的问题8. python - Mac 安装 MySQLdb时 报错,所有过程都按照网上说的做的,还是报错,求大神帮助9. datetime - Python如何获取当前时间10. 现在大家是用Mysql还是mariaDb?

网公网安备