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

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

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

要获取此信息,请查询 sde_table_registry ArcSDE 系统表以获取要插入记录的表的注册 ID。拥有注册 ID 之后,可标识与该表对应的 i 表,因为 i 表与其业务表通过注册 ID 相关联。i 表存储在拥有对应表的用户的方案中。

在插入语句中包括 Next_RowID 函数,可以使用下一有效值填充 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))', 12);
    
  3. 可继续编辑,如果完成编辑则将编辑内容提交到数据库。

相关主题

9/15/2013