MongoDB高级查询-shell篇 续

转载自 ---- http://pangwu86.iteye.com/blog/723851

 

接上篇~~~~~

 

sort()     排序


这个非常实用。即 sql 语言中的 OrderBy

 

db.myCollection.find().sort( { ts : -1 } )

 

也可以多个字段排序

 

db.myCollection.find().sort( { ts : -1 ,ds : 1 } )

 

这里的 1 代表升序, -1 代表降序。


经过 ME 的实验,小于 0 的数字就是降序, 0 以上(包括 0 )就是升序。

 

 

 

 

 

 

limit()   skip()

 

这两个 ME 想连起来讲,他们就是你实现数据库分页的好帮手

 

limit() 控制返回结果数量,如果参数是 0 ,则当作没有约束, limit() 将不起作用。

 

skip() 控制返回结果跳过多少数量,如果参数是 0 ,则当作没有约束, skip() 将不起作用,或者说跳过了 0 条。

 

例如:

 

 db.test.find().skip(5).limit(5)

 

结果就是取第 6 条到第 10 条数据。

 

 

 

 

 

 

 

 

snapshot()    (没有尝试)

 

 

 

 

 

 

count()    条数

 

返回结果集的条数。

 

db.test.count()

 

在加入 skip() limit() 这两个操作时,要获得实际返回的结果数,需要一个参数 true ,否则返回的是符合查询条件的结果总数。

 

例子如下:

 

> db.test.find().skip(5).limit(5).count()

9

> db.test.find().skip(5).limit(5).count(true)

4

 

 

 

 

group()   ( 没有尝试 )

 

 

###########  华丽丽的分割线  #############

 

 

关于在控制台中的查询差不多就这么多了,可以说这些查询都是普通 Sql 语句中进行单表查询的一些操作,貌似没有看到涉及多表查询,即不同的 collection 间的关联查询。

所以在设计表结构的时候,常用的一些基于关系数据库的表的设计方式已经不再适用。

但是不得不说,单表查询(应该说是 collection 查询)的功能还是灰常灰常强大的。

 

 

下次讲解下使用 JAVA 语言的 Driver 怎么实现上面的查询的。




PS:oh my lady gaga!这个排版太有问题了。ME下次得好好搞搞……

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值