[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语句的使用.

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

相关推荐
©️2020 CSDN 皮肤主题: Age of Ai 设计师:meimeiellie 返回首页