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>
表示不包含.
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语句的使用.
-
如何判断命令的查询时间