比较MongoDB中的版本

问题描述 投票:4回答:2

只是想知道是否有人能想出更聪明的方法来做到这一点......

假设我在MongoDB中有一些版本属性的文档,例如{ ..., version: { major: 1, minor: 2, patch: 13 } }{ ..., version: "1.2.13" },如果它更容易的话。

查找版本为X.Y.Z或更高版本的所有文档的最简单方法是什么?我现在这样做的方式基本上是一个巨大的$和条款。

mongodb versioning nosql
2个回答
3
投票

你的第一个设计实际上非常好。原因是因为您可以将字段majorminorpatch编入索引以进行快速读取。

查询数据实际上比使用$and查询容易得多。您可以在匹配字段上使用基本查询:

EG

db.versions.find({major:1,minor:2,patch:20}) //give me documents of version 1.2.20
db.versions.find({major:1}) //give me all documents with major version 1
db.versions.find({major:1,minor:{$gte:2,$lte:5}}) //give me all documents of major version and minor versions between 2 and 5 inclusive.

你可以创建一个索引

db.versions.ensureIndex({major:1,minor:1,patch:1})

$and查询主要用于您希望多次在同一字段上运行更复杂查询的情况。例如,如果您想获得主要版本1和2,则可以使用$and

db.versions.find({major:1,major:2})实际上只会返回主要版本2的文档。但是,db.versions.find({a:$all:[1,2]})在这种情况下也会起作用。理想情况下,您应该尽可能避免使用$and,因为它实际上会为$and数组中的每个表达式生成多个查询并执行联合。这比我上面提供的查询样本贵得多。


1
投票

如果您使用固定数量的数字作为版本号并将其存储为字符串,您应该能够使用$gte

"001.002.0013" > "001.002.0011" = true
"001.003.0013" > "001.002.0013" = true
"002.000.0000" > "001.002.0013" = true
"001.002.0012" > "001.002.0013" = false
"001.001.0013" > "001.002.0013" = false
© www.soinside.com 2019 - 2024. All rights reserved.