让我们考虑一下我们有:
1 2 3
4 5 6
7 8 9
您可以通过不同的方式将矩阵存储为 mongodb 中的嵌入数组:
1.将矩阵表示为一维数组并存储如下:
{
_id: "1",
matrix: [1,2,3,4,5,6,7,8,9],
width: 3, // or store just size in case of NxN
height: 3,
}
然后要增加矩阵的第三个元素,您将需要以下更新:
db.matrix.update({_id: 1}, { $inc : { "matrix.2" : 1 } }
这种方法非常轻量级,因为您存储尽可能少的数据,但您将始终需要计算要更新的元素的位置,并且需要编写额外的代码来在驱动程序中反序列化矩阵。
2.按以下方式存储矩阵:
{
_id: "1",
matrix: [
{xy: "0-0", v: 1},
{xy: "1-0", v: 2},
{xy: "2-0", v: 3},
{xy: "0-1", v: 4},
...
]
}
然后要增加矩阵中第一行的第三个元素,您将需要以下更新:
db.matrix.update({_id: 1, "matrix.xy": 2-0 }, { $inc : { "matrix.$.v" : 1 } }
从驱动程序方面来看,这种方法应该更简单,但是您需要在数据库中存储更多信息。
选择你更喜欢的。