跨库更新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
相关推荐
2401_863801461 天前
3DTiles总体介绍,什么是3DTiles,主要用途
3d·arcgis·3dtiles
城数派3 天前
ArcGIS中的色带配色方案
arcgis·信息可视化·数据分析
奔跑的呱呱牛3 天前
arcgis-to-geojson双向转换工具库
arcgis·json
da-peng-song5 天前
ArcGIS Desktop使用入门(四)—— 解决ArcGIS 界面字太小,DPI分辨率高
arcgis·界面字体小
liuccn5 天前
使用GDAL实现栅格数据的瓦片生成
arcgis
qq_283720056 天前
Nest.js 连接达梦 DM8 数据库实战和避坑指南
arcgis
liuccn6 天前
GeoTools跟GDAL 库的关系与区别以及应用场景
java·arcgis
trojan__7 天前
arcgis如何自定义图例
arcgis
角砾岩队长8 天前
ArcGIS属性字段常见计算方法
arcgis
AAIshangyanxiu9 天前
基于ArcGIS、InVEST与RUSLE水土流失模拟及分析
arcgis·土壤侵蚀·invest·水土流失·rusle