如果数据不参与地理数据库行为,则可在地理数据库中使用 SQL 更新数据、将数据插入非版本化表或从其中删除数据。有关无法使用 SQL 编辑的数据类型和地理数据库行为类型的详细信息,请参阅可使用 SQL 编辑何种数据类型?。
已注册到地理数据库的所有数据都具有由系统维护的唯一非空 ObjectID(行 ID)字段。在地理数据库中使用 SQL 将记录插入非版本化表时,必须为 ObjectID 提供唯一的值。执行 Next_RowID 过程来获取下一可用的 ObjectID 值。然后在 INSERT 语句中使用该值来填充记录的 ObjectID 字段。
这组说明介绍如何在非版本化表中每次更新一行以及如何插入一个 ObjectID。您很可能要编写例程或客户端程序来检索 ObjectID 和更新数据。
- 登录到 SQL 编辑器,例如 Microsoft SQL Server Management Studio 中的 SQL 编辑器。
请确保以拥有数据编辑权限的用户身份登录到数据库。
- 执行 Next_RowID 存储过程以获取 ObjectID 字段的值。
在此例中,gisdata4 是用于存储 farmland 表的方案。
DECLARE @id as integer EXEC dbo.next_rowid 'gisdata4', 'farmland', @id OUTPUT; SELECT @id "Next ObjectID"; Next ObjectID 423
- 使用从前一个语句返回的值填充所插入记录的 ObjectID 字段。
INSERT INTO gisdata4.farmland (objectid,crop,shape) VALUES ( 423, 'oats', geography::STGeomFromText('POLYGON((-111.85897004 33.25178949, -111.86899617 33.25065270, -111.86887014 33.25062350, -111.85884555 33.25176951, -111.85897004 33.25178949))', 4267) );
- 可继续编辑,如果完成编辑则将编辑内容提交到数据库。
如果该表还包含 GUID 或全局 ID 字段,则还必须为此字段提供一个唯一的值。有关详细信息,请参阅使用 SQL 将值插入到 SQL Server 中的全局 ID 列中。