SDE用户多表空间管理

本文下面内容将以Oracle10g为例,详细介绍如何使用SDE管理多个表空间,如何将不同的数据存到相应的表空间下。

     当使用SDE管理较大的数据量时,可先将数据类型、用途等进行分类,然后分别存储在不同的表空间里;这样不仅对管理的数据进行了合理的规划和分类,同时由于这些表空间可由SDE用户或其他用户统一管理,因此又有效地减轻了SDE本身的负荷。

1:创建表空间

在Oracle中创建存储数据的表空间TEST。

createtablespaceTESTdatafile'E:\oracle\product\oradata\azuay/TEST.dbf'size160mautoallocate;

2:修改DBTUNE表参数

如下图所示,通常情况下在ArcCatalog中向SDE复制数据时,数据默认是进入到Config.Keyword列为“DEFAULTS”的表空间中,即SDE默认的表空间。只要在SDE中创建TEST关键字,并建立其与TEST表空间的关联,就可以实现用SDE用户来管理TEST表空间。

通过Oracle10g客户端或PL/SQL打开SDE.DBTUNE表,如下图所示。SDE表空间对应的关键字“DEFAULTS”在DBTUNE表中有详细的说明,包括有关的参数;因此,在SDE中创建TEST关键字,只需在DBTUNE表中按DEFAULTS的参数格式和内容,创建TEST的参数表述信息即可。

使用sql语句创建TEST表,该表与dbtune表结构一样,但是只包含DEFAULTS的参数信息

createtable SDE.TESTasselect*from sde.dbtune where keyword='DEFAULTS'

使用sql语句更新KEYWORD列值为“TEST”。

update SDE.TESTset keyword='TEST'

最为重要的一步是对CONFIG_STRING列值的修改。由于DEFAULTS关键字CONFIG_STRING列的信息是在创建SDE表空间时建立的,其默认关联的是SDE表空间,因此在其信息中并没有表空间的信息。如下图所示

TEST关键字是后来创建的,因此在其参数信息的CONFIG_STRING列中需要加上表空间的信息。如下图所示

使用sql语句

update sde.TESTset CONFIG_STRING=concat('TABLESPACE TEST ',to_char(CONFIG_STRING))wheresubstr(to_char(config_string),1,7)='PCTFREE'

更新CONFIG_STRING列的值。注意:并非所有的CONFIG_STRING列值都需要更新,只要将现有列值中是以PCTFREE开头的列更新即可。

使用sql语句

insertinto sde.dbtuneselect*from sde.TEST

将TEST表中的信息导入到DBTUNE表中

到此步骤为止,完成了对DBTUNE表的修改,可以实现SDE用户对多表空间的管理了。

SDE用户管理多表空间

在ArcCatalog下向SDE中复制数据如下图

导入的数据表都在TEST表空间下。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要清除SDE空间中的垃圾数据,可以使用以下步骤: 1. 首先,使用ArcCatalog或ArcMap中的Catalog窗口连接到要清除的SDE数据库。 2. 右键单击要清除的SDE图层,选择“属性”选项。在“属性”窗口中,选择“空间参考”选项卡,记录空间参考的名称。 3. 打开ArcToolbox中的“数据管理工具”>“清理”>“清理SDE垃圾数据”工具。 4. 在“清理SDE垃圾数据”工具中,选择要清理的SDE图层,选择要清理的垃圾数据类型(例如,无效的几何体、重复的要素等),并选择要清理的空间参考。 5. 点击“运行”按钮开始清理。 请注意,清除SDE空间中的垃圾数据可能需要一些时间,具体时间取决于数据量的大小和计算机的性能。另外,清除垃圾数据可能会影响到SDE数据的完整性和一致性,因此在进行此操作之前,请务必备份SDE数据。 ### 回答2: Oracle SDE Layers 是一种在 Oracle 数据库中存储和管理空间数据的技术。当使用 SDE Layers 存储空间数据时,有时候会存留一些垃圾数据,这些数据可能是由于删除或修改数据时没有完全清理而产生的。 清除 SDE 空间垃圾数据的方法有以下几种: 1. 使用 ArcSDE command line 工具:可以使用 sdelayer -o delete 命令来删除指定中的垃圾数据。这个命令将会把那些没有被任何几何要素引用的几何类型和相关的属性记录从中删除。 2. 使用 ArcGIS 数据完整性检查工具:可以使用 ArcGIS 中提供的数据完整性检查工具来识别并删除中的垃圾数据。这个工具会检测中的每一行记录,如果发现某一行记录没有被任何几何要素引用,那么就会将其标记为垃圾数据,并且可以选择性地删除它们。 3. 手动清理:可以通过编写 SQL 查询语句来手动清理 SDE Layers 中的垃圾数据。通过查询数据库中的关联,找到不再被任何几何要素引用的记录,并将其删除。 无论使用哪种方法,清除 SDE Layers 中的垃圾数据都需要谨慎操作,确保不会误删有效数据。建议在清理之前先备份数据,以防万一。使用适当的工具和技术方法来清除垃圾数据,可以有效提升数据库性能和数据的完整性。 ### 回答3: 清除SDE空间垃圾数据可以通过以下步骤进行: 1. 首先,连接到Oracle数据库中的SDE用户。可以使用SQL*Plus或SQL Developer等数据库工具。 2. 检查SDE用户下的所有空间,识别存在垃圾数据的。可以使用以下SQL语句检索所有空间的名称: ```sql SELECT table_name FROM all_tables WHERE owner = 'SDE' AND table_name LIKE 'SDE%' ``` 3. 对于每个空间,可以采取以下方法清除垃圾数据: - 方法一:使用ArcGIS工具,如ArcCatalog或ArcMap等,连接到SDE数据库,打开要清理的图层,然后选择"Manage > Purge > Purge All"清除所有垃圾数据。这将删除不再被任何要素类参考的空间数据。 - 方法二:手动执行SQL语句来删除垃圾数据。在执行之前,建议先备份相关的数据。以下是一个示例SQL语句,用于删除指定中的垃圾数据,并针对需要进行清理的每个进行修改: ```sql DELETE FROM sde.table_name WHERE sde_column_name IS NULL ``` 在该语句中,"table_name"是要清除垃圾数据的的名称,"sde_column_name"是一个包含空间数据的列的名称(例如SHAPE或GEOMETRY)。 4. 在清除垃圾数据后,可以使用SDE命令重新创建空间索引以优化空间查询性能。可以使用以下命令进行重新创建空间索引: ```sql SDELAYER -o alter -l table_name,-1 sde:oracle11g:sde ``` 在该命令中,"table_name"是要重新创建空间索引的的名称。 5. 最后,验证清除操作是否成功,通过查询相关空间的数据进行确认。 请注意,清除空间垃圾数据涉及对数据库进行修改和删除操作,因此在执行操作之前,请确保已进行适当的备份,并在生产环境中谨慎操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值