MongoDB导入shapefile数据的具体方法是什么
Admin 2022-05-27 群英技术资讯 365 次浏览
两种解决方案:
一、将整个shapefile转为GeoJSON然后直接导入mongoDB数据库中
首先,将shapefile数据转为WGS84地理坐标,然后使用GDAL的命令行工具ogr2ogr进行格式的转换,转换命令如下:
ogr2ogr -f geoJSON continents.json continents.shp
删除生成JSON文件的前两行{ "type": "FeatureCollection",和最后一行}。
最后,使用mongodb的mongoimport工具进行导入:
mongoimport --db world --collection continents < continents.json
这样子整个shapefile文件在mongodb中是以一个document存在的。
二、更加细粒度的存储方法是将shapefile中的每个feature取出来转为GeoJSON存入mongodb
具体实现代码入下(Java版本):
package cn.tzy.mongodb; import java.io.File; import java.io.IOException; import java.io.StringWriter; import org.bson.Document; import org.geotools.data.FileDataStore; import org.geotools.data.FileDataStoreFinder; import org.geotools.data.simple.SimpleFeatureIterator; import org.geotools.data.simple.SimpleFeatureSource; import org.geotools.geojson.feature.FeatureJSON; import org.opengis.feature.simple.SimpleFeature; import com.mongodb.MongoClient; import com.mongodb.client.MongoCollection; import com.mongodb.client.MongoDatabase; public class MongoEx { public static void main(String[] args) throws IOException { final String IP_ADDRESS = "127.0.0.1"; final String DB_NAME = "SpatialFeatures"; final String COLLECTION_NAME = "continents"; final String SHAPE_FILE = "/home/theone/Data/World/continent.shp"; MongoClient client = new MongoClient(IP_ADDRESS, 27017); MongoDatabase db = client.getDatabase(DB_NAME); db.createCollection(COLLECTION_NAME); MongoCollection<Document> coll = db.getCollection(COLLECTION_NAME); File shapeFile = new File(SHAPE_FILE); FileDataStore store = FileDataStoreFinder.getDataStore(shapeFile); SimpleFeatureSource sfSource = store.getFeatureSource(); SimpleFeatureIterator sfIter = sfSource.getFeatures().features(); // 依次取出每一个Feature转为GeoJSON格式,然后插入到collection中 while (sfIter.hasNext()) { SimpleFeature feature = (SimpleFeature) sfIter.next(); FeatureJSON fjson = new FeatureJSON(); StringWriter writer = new StringWriter(); fjson.writeFeature(feature, writer); String sjson = writer.toString(); Document doc = Document.parse(sjson); coll.insertOne(doc); } client.close(); } }
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
mongodb数据库删除语句是db.dropDatabase(),此语句可以删除当前数据库,所以使用此语句需要先使用use命令切换到指定数据库。
这篇文章主要给大家总结介绍了关于MongoDB日常使用的一些技巧与注意事项,文中通过示例代码介绍的非常详细,对大家学习或者使用MongoDB具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
Limit与Skip在MongoDB中是经常需要使用到的,但是对于Limit与Skip的使用方法并不是所有用户们都了解,那么你知道MongoDB中如何使用Limit与Skip吗?如果还不了解的小伙伴们不妨一起看看吧。
MongoDB怎样进行性能优化,过程是什么?一些朋友可能会遇到这方面的问题,对此在下文小编向大家来讲解一下,内容详细,易于理解,希望大家阅读完这篇能有收获哦,有需要的朋友就往下看吧!
mongodb中可以使用find()方法查询文档,语法格式为db.collection.find(query,projection)。
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008