mongodb如何对子文档进行分页
文档结构如下:
<code>{ "_id" : ObjectId("55dc145ef754a3342000002d"), "id" : 12, "title" : "炎炎夏日,跟我一起High翻天!", "content" : "酷暑7月,简直不能忍~~~!夏天。就应该是被西瓜,冰镇可乐,全家桶,空调和游戏包围着的天堂。外面的世界纷纷扰扰与我无关~~哇哈哈哈!!", "thumb" : "/201506/5592560017b6a.jpg", "banner" : "/201506/559255fa5366d.jpg", "order" : 11, "publish_time" : "2015-08-25", "game_num" : 14, "games" : [ { "id" : 1128, "name_zh" : "追击野兽", "apk_size" : "38.15M", "apk_version_name" : "1.0.6", "apk_package_name" : "com.miniclip.beastquest", "apk_version_code" : "18", "game_rank" : 8, "customize_update_time" : "2015-05-18 00:00:00", }, { "id" : 3276, "name_zh" : "世界僵尸大联盟", "apk_size" : "33.88M", "apk_version_name" : "3.3.3237", "apk_package_name" : "com.proletariat.worldzombination", "apk_version_code" : "33537", "game_rank" : 8, "customize_update_time" : "2015-05-15 00:00:00", }, { "id" : 3416, "name_zh" : "围剿外星客", "apk_size" : "38.69M", "apk_version_name" : "1.7.1", "apk_package_name" : "com.outplayentertainment.aliencreeps", "apk_version_code" : "10070010", "game_rank" : 8, "customize_update_time" : "2015-04-25 00:00:00", }, { "id" : 10357, "name_zh" : "合金弹头:防御", "apk_size" : "47.13M", "apk_version_name" : "1.27.0", "apk_package_name" : "com.snkplaymore.android003", "apk_version_code" : "52", "game_rank" : 8, "customize_update_time" : "0000-00-00 00:00:00", }, { "id" : 10360, "name_zh" : "绿色忍者蛙年", "apk_size" : "47.7M", "apk_version_name" : "4", "apk_package_name" : "com.nitrome.greenninja", "apk_version_code" : "4", "game_rank" : 8, "customize_update_time" : "2015-06-30 15:52:10", }, { "id" : 10364, "name_zh" : "杀死马里奥", "apk_size" : "31.16M", "apk_version_name" : "1.0.6", "apk_package_name" : "air.com.keybol.plumber", "apk_version_code" : "1000006", "game_rank" : 7, "customize_update_time" : "2015-06-30 16:08:09", }, { "id" : 10366, "name_zh" : "通过繁殖征服世界", "apk_size" : "44.83M", "apk_version_name" : "1.0.2", "apk_package_name" : "com.kt.SpermWarWorldWide_G", "apk_version_code" : "10002", "game_rank" : 8, "customize_update_time" : "2015-06-30 16:21:22", }, { "id" : 10229, "name_zh" : "冰块切割", "apk_size" : "7.14M", "apk_version_name" : "2.4.6", "apk_package_name" : "com.hyperkani.sliceice", "apk_version_code" : "30", "game_rank" : 7, "customize_update_time" : "2014-11-04 00:00:00", }, { "id" : 10356, "name_zh" : "吃冰淇淋的怪房子", "apk_size" : "33.56M", "apk_version_name" : "1.0.2", "apk_package_name" : "com.firedroid.icecreamnomsters", "apk_version_code" : "4", "game_rank" : 8, "customize_update_time" : "0000-00-00 00:00:00", }, { "id" : 10358, "name_zh" : "来杯果汁", "apk_size" : "42.11M", "apk_version_name" : "1.6.21", "apk_package_name" : "air.com.sgn.juicejam.gp", "apk_version_code" : "1006021", "game_rank" : 6, "customize_update_time" : "0000-00-00 00:00:00", }, { "id" : 10362, "name_zh" : "梦游先生", "apk_size" : "48.52M", "apk_version_name" : "1.00", "apk_package_name" : "com.BEbit.MrSnoozleberg", "apk_version_code" : "1", "game_rank" : 8, "customize_update_time" : "2015-06-30 15:58:13", }, { "id" : 10363, "name_zh" : "清凉方冰冰", "apk_size" : "23.14M", "apk_version_name" : "1.1", "apk_package_name" : "com.unilever.CoolCubeszzc", "apk_version_code" : "2", "game_rank" : 6, "customize_update_time" : "2015-06-30 16:04:56", }, { "id" : 10365, "name_zh" : "嗜血狂鲨2", "apk_size" : "9.9M", "apk_version_name" : "2.6.1", "apk_package_name" : "com.fgol.shark2", "apk_version_code" : "13", "game_rank" : 8, "customize_update_time" : "2015-06-30 16:15:58", }, { "id" : 10367, "name_zh" : "外星人爱牛奶", "apk_size" : "23.86M", "apk_version_name" : "1.0.7", "apk_package_name" : "air.com.rightfusion.alienslikemilk", "apk_version_code" : "1000007", "game_rank" : 8, "customize_update_time" : "2015-06-30 16:28:17", } ] }</code>
如何对子文档games进行分页查询
比如一次只取3条数据
<code>{ "id" : 1128, "name_zh" : "追击野兽", "apk_size" : "38.15M", "apk_version_name" : "1.0.6", "apk_package_name" : "com.miniclip.beastquest", "apk_version_code" : "18", "game_rank" : 8, "customize_update_time" : "2015-05-18 00:00:00", }, { "id" : 3276, "name_zh" : "世界僵尸大联盟", "apk_size" : "33.88M", "apk_version_name" : "3.3.3237", "apk_package_name" : "com.proletariat.worldzombination", "apk_version_code" : "33537", "game_rank" : 8, "customize_update_time" : "2015-05-15 00:00:00", }, { "id" : 3416, "name_zh" : "围剿外星客", "apk_size" : "38.69M", "apk_version_name" : "1.7.1", "apk_package_name" : "com.outplayentertainment.aliencreeps", "apk_version_code" : "10070010", "game_rank" : 8, "customize_update_time" : "2015-04-25 00:00:00", } }</code>
回复内容:
文档结构如下:
<code>{ "_id" : ObjectId("55dc145ef754a3342000002d"), "id" : 12, "title" : "炎炎夏日,跟我一起High翻天!", "content" : "酷暑7月,简直不能忍~~~!夏天。就应该是被西瓜,冰镇可乐,全家桶,空调和游戏包围着的天堂。外面的世界纷纷扰扰与我无关~~哇哈哈哈!!", "thumb" : "/201506/5592560017b6a.jpg", "banner" : "/201506/559255fa5366d.jpg", "order" : 11, "publish_time" : "2015-08-25", "game_num" : 14, "games" : [ { "id" : 1128, "name_zh" : "追击野兽", "apk_size" : "38.15M", "apk_version_name" : "1.0.6", "apk_package_name" : "com.miniclip.beastquest", "apk_version_code" : "18", "game_rank" : 8, "customize_update_time" : "2015-05-18 00:00:00", }, { "id" : 3276, "name_zh" : "世界僵尸大联盟", "apk_size" : "33.88M", "apk_version_name" : "3.3.3237", "apk_package_name" : "com.proletariat.worldzombination", "apk_version_code" : "33537", "game_rank" : 8, "customize_update_time" : "2015-05-15 00:00:00", }, { "id" : 3416, "name_zh" : "围剿外星客", "apk_size" : "38.69M", "apk_version_name" : "1.7.1", "apk_package_name" : "com.outplayentertainment.aliencreeps", "apk_version_code" : "10070010", "game_rank" : 8, "customize_update_time" : "2015-04-25 00:00:00", }, { "id" : 10357, "name_zh" : "合金弹头:防御", "apk_size" : "47.13M", "apk_version_name" : "1.27.0", "apk_package_name" : "com.snkplaymore.android003", "apk_version_code" : "52", "game_rank" : 8, "customize_update_time" : "0000-00-00 00:00:00", }, { "id" : 10360, "name_zh" : "绿色忍者蛙年", "apk_size" : "47.7M", "apk_version_name" : "4", "apk_package_name" : "com.nitrome.greenninja", "apk_version_code" : "4", "game_rank" : 8, "customize_update_time" : "2015-06-30 15:52:10", }, { "id" : 10364, "name_zh" : "杀死马里奥", "apk_size" : "31.16M", "apk_version_name" : "1.0.6", "apk_package_name" : "air.com.keybol.plumber", "apk_version_code" : "1000006", "game_rank" : 7, "customize_update_time" : "2015-06-30 16:08:09", }, { "id" : 10366, "name_zh" : "通过繁殖征服世界", "apk_size" : "44.83M", "apk_version_name" : "1.0.2", "apk_package_name" : "com.kt.SpermWarWorldWide_G", "apk_version_code" : "10002", "game_rank" : 8, "customize_update_time" : "2015-06-30 16:21:22", }, { "id" : 10229, "name_zh" : "冰块切割", "apk_size" : "7.14M", "apk_version_name" : "2.4.6", "apk_package_name" : "com.hyperkani.sliceice", "apk_version_code" : "30", "game_rank" : 7, "customize_update_time" : "2014-11-04 00:00:00", }, { "id" : 10356, "name_zh" : "吃冰淇淋的怪房子", "apk_size" : "33.56M", "apk_version_name" : "1.0.2", "apk_package_name" : "com.firedroid.icecreamnomsters", "apk_version_code" : "4", "game_rank" : 8, "customize_update_time" : "0000-00-00 00:00:00", }, { "id" : 10358, "name_zh" : "来杯果汁", "apk_size" : "42.11M", "apk_version_name" : "1.6.21", "apk_package_name" : "air.com.sgn.juicejam.gp", "apk_version_code" : "1006021", "game_rank" : 6, "customize_update_time" : "0000-00-00 00:00:00", }, { "id" : 10362, "name_zh" : "梦游先生", "apk_size" : "48.52M", "apk_version_name" : "1.00", "apk_package_name" : "com.BEbit.MrSnoozleberg", "apk_version_code" : "1", "game_rank" : 8, "customize_update_time" : "2015-06-30 15:58:13", }, { "id" : 10363, "name_zh" : "清凉方冰冰", "apk_size" : "23.14M", "apk_version_name" : "1.1", "apk_package_name" : "com.unilever.CoolCubeszzc", "apk_version_code" : "2", "game_rank" : 6, "customize_update_time" : "2015-06-30 16:04:56", }, { "id" : 10365, "name_zh" : "嗜血狂鲨2", "apk_size" : "9.9M", "apk_version_name" : "2.6.1", "apk_package_name" : "com.fgol.shark2", "apk_version_code" : "13", "game_rank" : 8, "customize_update_time" : "2015-06-30 16:15:58", }, { "id" : 10367, "name_zh" : "外星人爱牛奶", "apk_size" : "23.86M", "apk_version_name" : "1.0.7", "apk_package_name" : "air.com.rightfusion.alienslikemilk", "apk_version_code" : "1000007", "game_rank" : 8, "customize_update_time" : "2015-06-30 16:28:17", } ] }</code>
如何对子文档games进行分页查询
比如一次只取3条数据
<code>{ "id" : 1128, "name_zh" : "追击野兽", "apk_size" : "38.15M", "apk_version_name" : "1.0.6", "apk_package_name" : "com.miniclip.beastquest", "apk_version_code" : "18", "game_rank" : 8, "customize_update_time" : "2015-05-18 00:00:00", }, { "id" : 3276, "name_zh" : "世界僵尸大联盟", "apk_size" : "33.88M", "apk_version_name" : "3.3.3237", "apk_package_name" : "com.proletariat.worldzombination", "apk_version_code" : "33537", "game_rank" : 8, "customize_update_time" : "2015-05-15 00:00:00", }, { "id" : 3416, "name_zh" : "围剿外星客", "apk_size" : "38.69M", "apk_version_name" : "1.7.1", "apk_package_name" : "com.outplayentertainment.aliencreeps", "apk_version_code" : "10070010", "game_rank" : 8, "customize_update_time" : "2015-04-25 00:00:00", } }</code>
<code>> db.test1.find().pretty() { "_id" : ObjectId("55dc145ef754a3342000002d"), "games" : [ { "id" : 1128, "name_zh" : "追击野兽", "customize_update_time" : "2015-05-18 00:00:00" }, { "id" : 3276, "name_zh" : "dasda", "customize_update_time" : "2015-05-15 00:00:00" }, { "id" : 3416, "name_zh" : "围剿外星客", "customize_update_time" : "2015-04-25 00:00:00" }, { "id" : 10357, "name_zh" : "合金弹头:防御", "customize_update_time" : "0000-00-00 00:00:00" }, { "id" : 10360, "name_zh" : "绿色忍者蛙年", "customize_update_time" : "2015-06-30 15:52:10" }, { "id" : 10364, "name_zh" : "杀死马里奥", "customize_update_time" : "2015-06-30 16:08:09" }, { "id" : 10366, "name_zh" : "通过繁殖征服世界", "customize_update_time" : "2015-06-30 16:21:22" }, { "id" : 10229, "name_zh" : "冰块切割", "customize_update_time" : "2014-11-04 00:00:00" }, { "id" : 10356, "name_zh" : "吃冰淇淋的怪房子", "customize_update_time" : "0000-00-00 00:00:00" }, { "id" : 10358, "name_zh" : "来杯果汁", "customize_update_time" : "0000-00-00 00:00:00" }, { "id" : 10362, "name_zh" : "梦游先生", "customize_update_time" : "2015-06-30 15:58:13" }, { "id" : 10363, "name_zh" : "清凉方冰冰", "customize_update_time" : "2015-06-30 16:04:56" }, { "id" : 10365, "name_zh" : "嗜血狂鲨2", "customize_update_time" : "2015-06-30 16:15:58" }, { "id" : 10367, "name_zh" : "外星人爱牛奶", "customize_update_time" : "2015-06-30 16:28:17" } ] }</code>
取games的前3条数据:
<code>> db.test1.find({"_id" : ObjectId("55dc145ef754a3342000002d")},{"games":{ "$slice":[0,3]}}).pretty() { "_id" : ObjectId("55dc145ef754a3342000002d"), "games" : [ { "id" : 1128, "name_zh" : "追击野兽", "customize_update_time" : "2015-05-18 00:00:00" }, { "id" : 3276, "name_zh" : "dasda", "customize_update_time" : "2015-05-15 00:00:00" }, { "id" : 3416, "name_zh" : "围剿外星客", "customize_update_time" : "2015-04-25 00:00:00" } ] }</code>
取第四条到第6条数据:
<code>> db.test1.find({"_id" : ObjectId("55dc145ef754a3342000002d")},{"games":{ "$slice":[3,3]}}).pretty() { "_id" : ObjectId("55dc145ef754a3342000002d"), "games" : [ { "id" : 10357, "name_zh" : "合金弹头:防御", "customize_update_time" : "0000-00-00 00:00:00" }, { "id" : 10360, "name_zh" : "绿色忍者蛙年", "customize_update_time" : "2015-06-30 15:52:10" }, { "id" : 10364, "name_zh" : "杀死马里奥", "customize_update_time" : "2015-06-30 16:08:09" } ] }</code>
依次类推,即可。 "$slice":[3,3] 第一个3表示查询数组下标的起始位置,第二个3表示取的数据条数。建议games不要过多,不然会超出文档限制16M。不过这个可能是设计问题,我多想了。
第二种方法:就是用代码从数据库中取出来,将games里面的每一个子文档封装成model,放在缓存中做分页,而不是数据库级别的分页也可实现
第三种方法:从数据可看出games里面的子文档是按照id进行排序的,那么也就是说子文档是可比较的,那么就可以使用$gt和$lt,接合$size取数据,我没有试。你可以尝试一下。不过$slice获取数组子集更方便一点。
用limit(n)可以限制只获取n条数据。skip(n)可以跳过n条数据,两者结合可以实现分页吧?不过skip比较消耗资源少用为妙。

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제









PHP 8.4는 상당한 양의 기능 중단 및 제거를 통해 몇 가지 새로운 기능, 보안 개선 및 성능 개선을 제공합니다. 이 가이드에서는 Ubuntu, Debian 또는 해당 파생 제품에서 PHP 8.4를 설치하거나 PHP 8.4로 업그레이드하는 방법을 설명합니다.

CakePHP는 PHP용 오픈 소스 프레임워크입니다. 이는 애플리케이션을 훨씬 쉽게 개발, 배포 및 유지 관리할 수 있도록 하기 위한 것입니다. CakePHP는 강력하고 이해하기 쉬운 MVC와 유사한 아키텍처를 기반으로 합니다. 모델, 뷰 및 컨트롤러 gu

CakePHP에서 데이터베이스 작업은 매우 쉽습니다. 이번 장에서는 CRUD(생성, 읽기, 업데이트, 삭제) 작업을 이해하겠습니다.

CakePHP에 로그인하는 것은 매우 쉬운 작업입니다. 한 가지 기능만 사용하면 됩니다. cronjob과 같은 백그라운드 프로세스에 대해 오류, 예외, 사용자 활동, 사용자가 취한 조치를 기록할 수 있습니다. CakePHP에 데이터를 기록하는 것은 쉽습니다. log() 함수는 다음과 같습니다.

VS Code라고도 알려진 Visual Studio Code는 모든 주요 운영 체제에서 사용할 수 있는 무료 소스 코드 편집기 또는 통합 개발 환경(IDE)입니다. 다양한 프로그래밍 언어에 대한 대규모 확장 모음을 통해 VS Code는
