ArcGIS Desktop

  • ArcGIS Pro
  • ArcMap

  • My Profile
  • 帮助
  • Sign Out
ArcGIS Desktop

ArcGIS Online

专为贵组织打造的制图平台

ArcGIS Desktop

全面的专业性 GIS

ArcGIS Enterprise

面向企业的 GIS

ArcGIS Developers

用于构建位置感知应用程序的工具

ArcGIS Solutions

适用于行业的免费模板地图和应用程序

ArcGIS Marketplace

获取适用于组织的应用程序和数据

  • 文档
  • 支持
Esri
  • 登录
user
  • 我的个人资料
  • 登出

ArcMap

  • 主页
  • 入门
  • 地图
  • 分析
  • 管理数据
  • 工具
  • 扩展模块

在 PostgreSQL 中使用 SQL 编辑非版本化的地理数据库 (geodatabase) 数据

如果数据不参与地理数据库行为,则可在地理数据库中使用 SQL 更新数据、将数据插入非版本化表或从其中删除数据。请参阅可使用 SQL 编辑何种数据类型? 以了解有关无法使用 SQL 编辑的数据类型和地理数据库行为类型的详细信息。

注:

如果要使用 SQL 编辑的非版本化表已可用于存档,则必须编辑表存档视图而不是表本身。该视图将自动更新某些 ArcGIS 维护的字段。有关详细信息,请参阅什么是存档视图及其相关主题。

已注册到地理数据库的所有数据都具有由系统维护的唯一非空 ObjectID(行 ID)字段。在地理数据库中使用 SQL 将记录插入非版本化表时,必须为 ObjectID 提供唯一的值。在插入语句中包括 Next_RowID 函数,可以使用下一有效值填充 ObjectID 字段。

注:

下一个可用 ObjectID 不一定是最后所插入 ObjectID 之后的下一个序号。某些客户端应用程序的 ObjectID 会进行批量分配,因此下一个可用 ObjectID 可能是许多大于您最后使用的 ObjectID 的编号。同样,批中任何未使用的 ObjectID 会返回到可用值池中,这意味着下一个可用 ObjectID 值可能实际上小于最后插入的 ObjectID 值。

这组说明介绍如何在非版本化表中每次更新一行以及如何插入一个 ObjectID。您很可能要编写例程或客户端程序来检索 ObjectID 和更新数据。

  1. 从 SQL 编辑器(例如 psql)登录到数据库。

    请确保以拥有数据编辑权限的用户身份登录到数据库。

  2. 使用 Next_RowID 函数填充 ObjectID 字段。

    在此例中,site_id 列是 ObjectID 字段,表名是 outbreak,并且表存储在 hmoot 方案中。

    INSERT INTO hmoot.outbreak (site_id, med_code,num_affected, shape) 
     VALUES (
      sde.next_rowid('hmoot', 'outbreak'), 
      'v-22a', 
      3, 
      ST_Point('point (12 36))', 4326
     );
    
  3. 可继续编辑,如果完成编辑则将编辑内容提交到数据库。

如果该表还包含 GUID 或全局 ID 字段,则还必须为此字段提供一个唯一的值。有关详细信息,请参阅 Next_GlobalID。

相关主题

  • Next_RowID
  • RowID_Name
  • 什么是 ObjectID?
  • 可使用 SQL 编辑何种数据类型?

ArcGIS Desktop

  • 主页
  • 文档
  • 支持

ArcGIS

  • ArcGIS Online
  • ArcGIS Desktop
  • ArcGIS Enterprise
  • ArcGIS
  • ArcGIS Developer
  • ArcGIS Solutions
  • ArcGIS Marketplace

关于 Esri

  • 关于我们
  • 招贤纳士
  • Esri 博客
  • 用户大会
  • 开发者峰会
Esri
分享您的想法。
Copyright © 2021 Esri. | 隐私政策 | 法律声明