[MongoDB] 如何只查询对象的某几个字断

Question

今天在开发的时候. 发现对象里面有时候有某些字断比较大. 导致查询和传输比较慢. 在此记录一下研究和探讨的过程.

对象如下

{
  fieldA:"100",
  fieldB:"xx",
  fieldC:"xxxxxxxxxxxxxxxx"<假设有1w个字符>
}

那么在有些的查询场景下面. fieldC其实是不需要查询和返回的. 比如类似select fieldA, fieldB from table. 那么在mongoDB内应该如何解决呢?


SolutionA - MongoDB语句查询

  • 默认查询
db.collection.find()
  • 指定字段 - 只查询某几个字断
db.tbl_user.find({}, {fieldA:1,fieldB:1} )
  • 指定字段 - 排除某几个字段
db.tbl_user.find({}, {fieldC:0} )
  • 小结
    如上所示. 可以使用db.collection.find({},{field,0}). 方式进行查询. 第一个{}表示字段的搜寻条件. 第二个{}内用于表示需要返回数据的列, 其中<fieldName:1>表示包含. <fieldName:0>表示不包含.

MongoDB查询指定字段(field)返回指定字段的方法

MongoDB查询返回指定字段


SolutionB - Spring集成的Query语句

那么都知道. 我们开发的时候是不会使用db.collection.find()这样使用的. 我们一般都是使用Spring-mongo帮助我们解决问题. 那么这个指定字段在spring-mongo内如何展现呢?

  • 使用Query对象.
Query query = new Query();
query.fields().include("fieldA").include("fieldB")
query.fields().exclude("fieldC")

参考链接等待补充.


Others

未完待续.

  • explatin语句的使用.

  • 如何判断命令的查询时间

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值