MongoDB导入shapefile数据的具体方法是什么
Admin 2022-05-27 群英技术资讯 1020 次浏览
这篇文章主要讲解了“MongoDB导入shapefile数据的具体方法是什么”,文中的讲解内容简单、清晰、详细,对大家学习或是工作可能会有一定的帮助,希望大家阅读完这篇文章能有所收获。下面就请大家跟着小编的思路一起来学习一下吧。
两种解决方案:
一、将整个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主分片是什么?很多刚接触的MongoDB数据库的朋友可能对主分片不是很了解,对此这篇文章小编就给大家介绍一下MongoDB主分片,感兴趣的朋友就继续往下看吧。
这篇文章主要介绍的是关于mongodb备份的内容,包括mongodb增量备份和mongodb全量备份的实现,感兴趣的朋友可以参考,下面我们就一起来看看mongodb备份脚本。
打开mongodb数据库的方法:在cmd进入mongodb安装目录下的bin目录,然后执行“mongod -db:path D\mongod\data\db”命令即可打开。
使用mongodb做集群的方法:1、使用Replica Set副本实现集群。2、使用Sharding分片方式实现。3、使用Master-slave主备方式实现。
mongodb多表联查的方法:1、首先用from关联主从表名;2、用as查询结果名;3、用Aggregation进行多条件查询;4、查询结果赋给results;5、用print()输出查询结果。
成为群英会员,开启智能安全云计算之旅
立即注册关注或联系群英网络
7x24小时售前:400-678-4567
7x24小时售后:0668-2555666
24小时QQ客服
群英微信公众号
CNNIC域名投诉举报处理平台
服务电话:010-58813000
服务邮箱:service@cnnic.cn
投诉与建议:0668-2555555
Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 ICP核准(ICP备案)粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008