java 利用gdal,将gdb中图层转为postgresql的表

文章目录

简要说明

在java开发中,将gdb的图层数据转为postgresql的空间表

maven依赖

java 复制代码
		<!--需要安装完gdal后,本地install gdal包才能使用 -->
		<!--gdal安装可参考 https://blog.csdn.net/qq_41613913/article/details/135743562 -->
		<dependency>
            <groupId>org.gdal</groupId>
            <artifactId>gdal</artifactId>
            <version>3.7.3</version>
        </dependency>

样例代码

java 复制代码
public static void main(String[] args) {
        // 注册所有的驱动
        ogr.RegisterAll();
        // 为了支持中文路径,请添加下面这句代码
        gdal.SetConfigOption("GDAL_FILENAME_IS_UTF8","YES");
        // 为了使属性表字段支持中文,请添加下面这句
        gdal.SetConfigOption("SHAPE_ENCODING", "CP936");

        String strVectorFile = "D:\\gdb\\test.gdb";
        //打开数据
        DataSource gdbDataSource = ogr.Open(strVectorFile,0);
        Layer gdbLayer = gdbDataSource.GetLayerByName("图层名称");
        if (gdbLayer == null)
        {
            System.out.println("获取gdb图层失败!");
            return;
        }

        Driver postgreSQLDriver = ogr.GetDriverByName("PostgreSQL");
        if(postgreSQLDriver == null){
            System.out.println("不支持 PostgreSQL 驱动");
            return;
        }
        //GDAL连接PostGIS
        String path = "PG:dbname=数据库名称 host=主机地址 port=端口 user=用户名称 password=密码";
        DataSource pgDataSource = postgreSQLDriver.Open(path, 1);
        if(pgDataSource == null){
            System.out.println("GDAL连接PostGIS数据库失败!");
            return;
        }
        //直接复制模式,这样以后做追加有问题
        pgDataSource.CopyLayer(gdbLayer, "表名", null);
        
        pgDataSource.delete();
        gdbDataSource.delete();
        gdal.GDALDestroyDriverManager();
        System.out.println("gd图层导入成功!");
    }
相关推荐
烤麻辣烫几秒前
黑马程序员苍穹外卖(新手)DAY10
java·开发语言·学习·spring·intellij-idea
q***7355几秒前
Spring Boot应用关闭分析
java·spring boot·后端
u***45163 分钟前
Spring Boot中的404错误:原因、影响及处理策略
java·spring boot·后端
p***62997 分钟前
mysql-connector-java 和 mysql-connector-j的区别
android·java·mysql
程序员三明治7 分钟前
【Java】synchronized关键字详解:从字节码到对象头与锁升级
java·开发语言·juc·synchronized··锁升级
k***3888 分钟前
Spring Boot项目集成Redisson 原始依赖与 Spring Boot Starter 的流程
java·spring boot·后端
老虎06279 分钟前
Java基础面试题(11)—Java(泛型)
java·开发语言·windows
一 乐10 分钟前
宠物医院预约|宠物医院|基于SprinBoot+vue的宠物医院预约管理系统源码+数据库+文档)
java·前端·数据库·vue.js·后端·springboot
Seven9713 分钟前
数据结构-哈希表
java
k***38814 分钟前
oracle 12c查看执行过的sql及当前正在执行的sql
java·sql·oracle