跨库更新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
相关推荐
Lucky_Turtle11 小时前
【electron】一、安装,打包配置
javascript·arcgis·electron
GIS小小研究僧14 小时前
同一个栅格数据,为何在QGIS和ArcGIS Pro中打开后显示的数值范围不同?
arcgis·gis·qgis·rs
南飞测绘视界15 小时前
【实操教学】ArcGIS 如何进行定义坐标系
arcgis·坐标系·坐标系定义
wanzhong233315 小时前
ArcGIS学习-12 实战-综合案例
学习·arcgis
星空18 小时前
网络安全监控中心
安全·web安全·arcgis·地图·前段
柯南二号2 天前
【大前端】实现一个前端埋点SDK,并封装成NPM包
前端·arcgis·npm
没有梦想的咸鱼185-1037-16633 天前
如何利用ArcGIS探究环境与生态因子对水体、土壤、大气污染物等影响
arcgis·数据分析
新生GIS6 天前
arcgis-空间矫正工具(将下发数据A的信息放置原始数据B的原始信息并放置到成果数据C中,主要按下发数据A的范围)
arcgis
新生GIS9 天前
arcgis-提取范围中最大占比面积的信息或唯一值
arcgis
圆周率的后六位10 天前
GIS相关调研
arcgis·gis·supermap·gisbox·gis组件