经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » 数据库/运维 » MongoDB » 查看文章
mongodb 通过嵌入文档中的字段排序
来源:cnblogs  作者:吉姆杨  时间:2019/10/12 9:14:40  对本文有异议

 

mongodb中的全部数据:

  1. db.testInfo.find({})
  2. .sort({_id:-1})
  3. .limit(100)

查询结果:

  1. /* 1 createdAt:2019/10/11 下午5:12:50*/
  2. {
  3. "_id" : ObjectId("5da04792665cd81dc0d46d3d"),
  4. "name" : "jim2",
  5. "age" : 5,
  6. "list" : [
  7. {
  8. "title" : "a2",
  9. "price" : 1
  10. },
  11. {
  12. "title" : "a1",
  13. "price" : 5
  14. }
  15. ]
  16. },
  17.  
  18. /* 2 createdAt:2019/10/11 下午5:01:55*/
  19. {
  20. "_id" : ObjectId("5da04503665cd81dc0d46d3c"),
  21. "name" : "leo",
  22. "age" : 4,
  23. "list" : [
  24. {
  25. "title" : "a1",
  26. "price" : 3
  27. },
  28. {
  29. "title" : "d2",
  30. "price" : 2
  31. }
  32. ]
  33. },
  34.  
  35. /* 3 createdAt:2019/10/11 下午5:01:55*/
  36. {
  37. "_id" : ObjectId("5da04503665cd81dc0d46d3b"),
  38. "name" : "jason",
  39. "age" : 3,
  40. "list" : [
  41. {
  42. "title" : "a1",
  43. "price" : 2
  44. },
  45. {
  46. "title" : "c2",
  47. "price" : 1
  48. }
  49. ]
  50. },
  51.  
  52. /* 4 createdAt:2019/10/11 下午5:01:55*/
  53. {
  54. "_id" : ObjectId("5da04503665cd81dc0d46d3a"),
  55. "name" : "mark",
  56. "age" : 2,
  57. "list" : [
  58. {
  59. "title" : "a1",
  60. "price" : 3
  61. },
  62. {
  63. "title" : "b2",
  64. "price" : 4
  65. }
  66. ]
  67. },
  68.  
  69. /* 5 createdAt:2019/10/11 下午5:00:12*/
  70. {
  71. "_id" : ObjectId("5da0449c665cd81dc0d46d39"),
  72. "name" : "jim",
  73. "age" : 1,
  74. "list" : [
  75. {
  76. "title" : "a1",
  77. "price" : 1
  78. },
  79. {
  80. "title" : "a2",
  81. "price" : 2
  82. }
  83. ]
  84. }

 

通过嵌入文档中查询指定title的数据,然后根据price排序,注意需要排序时将查询的title也一并作为排序字段,否则顺序会错乱。

  1. db.testInfo.find({"list.title":"a1"})
  2. .sort({
  3. "list.title":1,
  4. "list.price":1
  5. });

查询结果:

  1. /* 1 createdAt:2019/10/11 下午5:00:12*/
  2. {
  3. "_id" : ObjectId("5da0449c665cd81dc0d46d39"),
  4. "name" : "jim",
  5. "age" : 1,
  6. "list" : [
  7. {
  8. "title" : "a1",
  9. "price" : 1
  10. },
  11. {
  12. "title" : "a2",
  13. "price" : 2
  14. }
  15. ]
  16. },
  17.  
  18. /* 2 createdAt:2019/10/11 下午5:01:55*/
  19. {
  20. "_id" : ObjectId("5da04503665cd81dc0d46d3b"),
  21. "name" : "jason",
  22. "age" : 3,
  23. "list" : [
  24. {
  25. "title" : "a1",
  26. "price" : 2
  27. },
  28. {
  29. "title" : "c2",
  30. "price" : 1
  31. }
  32. ]
  33. },
  34.  
  35. /* 3 createdAt:2019/10/11 下午5:01:55*/
  36. {
  37. "_id" : ObjectId("5da04503665cd81dc0d46d3a"),
  38. "name" : "mark",
  39. "age" : 2,
  40. "list" : [
  41. {
  42. "title" : "a1",
  43. "price" : 3
  44. },
  45. {
  46. "title" : "b2",
  47. "price" : 4
  48. }
  49. ]
  50. },
  51.  
  52. /* 4 createdAt:2019/10/11 下午5:01:55*/
  53. {
  54. "_id" : ObjectId("5da04503665cd81dc0d46d3c"),
  55. "name" : "leo",
  56. "age" : 4,
  57. "list" : [
  58. {
  59. "title" : "a1",
  60. "price" : 3
  61. },
  62. {
  63. "title" : "d2",
  64. "price" : 2
  65. }
  66. ]
  67. },
  68.  
  69. /* 5 createdAt:2019/10/11 下午5:12:50*/
  70. {
  71. "_id" : ObjectId("5da04792665cd81dc0d46d3d"),
  72. "name" : "jim2",
  73. "age" : 5,
  74. "list" : [
  75. {
  76. "title" : "a2",
  77. "price" : 1
  78. },
  79. {
  80. "title" : "a1",
  81. "price" : 5
  82. }
  83. ]
  84. }

  

 

原文链接:http://www.cnblogs.com/yangyuping/p/11655752.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号