跨库更新ArcGIS 某个Geodatabase FeatureClass

今天不讨论使用ArcGIS的工具,比如Pro和ArcPy进行迁移,今天讨论用纯数据库命令行方法进行更新,毕竟速度快,数据百分之百保真,而且方便任务化执行

环境:

源库: PG 11.5 X64 for linux

目标: KingbaseES V8R6 X64 for linux

应用所在机器: (需要安装pg的命令行工具,尽量安装跟目标库上一致的版本,如KingbaseES V8R6 是基于PG12.1修改的,那就安装PG12版本的PG和ArcGIS Pro)

前提:

两个库都开启了企业级地理数据库(都使用postgis建立了Geodatabase模型)

目标库和源库需要对应用机器免密登录数据库(服务器端设置免密或者中间机器设置密码文件都可以)

步骤:

  1. 使用ArcGIS Pro导入数据到源库中

  2. 导入数据结束后,使用pro在源库导出xml工作空间(只导出元数据)

3 使用Pro在目标库上,导入第二部导出的xml工作空间。

  1. 应用所在机器上执行如下命令(可以写成脚本,每天定时执行)
bash 复制代码
清除目标库上的数据
psql -h 192.168.100.51 -U sde -p 54321 -d arcmap1082create -c "truncate table poly100w"
TRUNCATE TABLE

导入数据
pg_dump -a -h 192.168.100.138 -U sde -d test -p 5432 -t poly100w |psql -h 192.168.100.51 -U sde -d arcmap1082create -p 54321
SET
SET
SET
SET
SET
 set_config
------------

(1 row)

SET
SET
SET
SET
COPY 1189032

重置objectid,以让pro能够编辑
psql -h 192.168.100.51 -U sde -p 54321 -d arcmap1082create -c "select sde.reset_rowid('sde','poly100w',t.value) from (select max(objectid) +1 as value from poly100w) as t(value);"
 reset_rowid
-------------
           0
(1 row)

修改范围,以让pro能正确显示
psql -h 192.168.100.51 -U sde -p 54321 -d arcmap1082create -c "update sde.sde_layers a set (minx,miny,maxx,maxy)=(select min(st_xmin(b.shape)),min(st_ymin(b.shape)),max(st_xmax(b.shape)),max(st_ymax(b.shape)) from poly100w b) where a.table_name='poly100w'"
UPDATE 1
  1. 这样就可以获得一个使用ArcGIS Pro正常打开的FeatureClass
相关推荐
CSDN_RTKLIB1 天前
arcgis投影后数据显示问题记录
arcgis
树谷-胡老师1 天前
1965–2022年中国大陆高分辨率分部门用水数据集,包含:灌溉用水、工业制造用水、生活用水和火电冷却
大数据·数据库·arcgis
zhu_zhu_xia2 天前
cesium添加原生MVT矢量瓦片方案
javascript·arcgis·webgl·cesium
瀚高PG实验室2 天前
Arcgis连接HGDB报错
数据库·arcgis·瀚高数据库
小小弯_Shelby3 天前
arcgis api for js 设置地图服务请求带有请求头信息
arcgis
白白李媛媛7 天前
上传Vue3+vite+Ts组件到npm官方库保姆级教程
前端·arcgis·npm
zm-v-159304339867 天前
ArcGIS 水文分析升级:基于深度学习的流域洪水演进过程模拟
人工智能·深度学习·arcgis
新中地GIS开发老师7 天前
新发布:26考研院校和专业大纲
学习·考研·arcgis·大学生·遥感·gis开发·地理信息科学
Cacciatore->7 天前
React 基本介绍与项目创建
前端·react.js·arcgis