5

当我尝试在 geometry 上创建索引时db.polygons.createIndex({"geometry":"2dsphere"}),它停在某个多边形上,错误代码为 16755。它说它Can't extract geo keysDuplicate vertices: 18 and 20

因此,经过进一步检查,当多边形中的 2 个节点靠近甚至重复时,似乎会发生这种情况。

然后我在 QGIS 中手动删除此节点并重试该过程,却发现另一个多边形存在相同问题。

我怎样才能解决这个问题而不必重复修复多边形>上传到MongoDB>创建索引的整个过程?有没有办法找出有多少多边形有这个问题?

4

2 回答 2

6

我遇到了类似的问题。我只需要在我的数据集中找到有效记录(我丢弃了重复顶点的记录)。

我重命名了集合 -

db.myCollection.renameCollection('myCollectionBk')

然后我将原始集合中的一条记录添加到新集合中,并向集合中添加地理空间索引

db.myCollection.insert(db.myCollectionBk.findOne()) // recreate the collection
db.myCollection.createIndex({geometry:"2dsphere"}) // create the index (assumes the geometry on the record is valid)
db.myCollection.remove({}) // remove the record

然后我将有效记录添加到新集合中。

db.myCollectionBk.find().forEach(function(x){
    db.myCollection.insert(x);
})

无效的记录会被简单地忽略。

在您的情况下,您可能希望从您的insert中获取WriteResult,并查看它是否成功。就像是

var errors = []
db.myCollectionBk.find().forEach(function(x){
    var result = db.myCollection.insert(x);
    if (result.writeError) {
        errors.push({x._id:result.writeError.errmsg});
    }
})

作为另一种选择,请查看这个问题(我无法让它工作)

于 2016-06-07T18:18:55.210 回答
1

所以我所做的是,我首先使用索引创建了集合,然后尝试使用 mongoimport 插入,这给了我成功插入的数量。

> db.someNewCollection.createIndex({"geometry":"2dsphere"})

要将 GeoJSON 插入 MongoDB,我执行了以下操作:

$ jq --compact-output ".features" yourGeoJSON > output.geojson
$ mongoimport --db someDB -c someNewCollection --file "output.geojson" --jsonArray
于 2016-08-11T08:59:27.660 回答