ArcSDE中空间数据的备份与恢复

 

  在采用文件形式空间数据的时代,空间数据的备份仅仅是操作系统中的文件拷贝、备份和归档的过程;而空间数据的恢复也不过是复制、覆盖的操作;在基于ArcSDE和关系型数据库的空间数据库时代,空间数据的备份更多的依赖于关系型数据库的备份和恢复技术,当然也不能缺少ArcSDE所提供的备份工具。按照备份的方式和对象,ArcSDE中空间数据的备份和恢复可以分为如下两类:指定空间数据对象的备份恢复,和整体空间数据库的备份恢复。

一、指定空间数据对象的备份和恢复

  这种方式主要用于备份指定的空间数据对象,比如某个图层和要素类、其中的某些满足特定条件的记录、甚至特定的版本。实现这种备份方式的方法主要是利用ArcSDE提供的管理工具:sdeexportsdeimport命令。它们的位置在%ArcSDEHOME%\bin\中。

其中,sdeexport用于将空间数据从ArcSDE Server上备份为单独的数据文件,而sdeimport用于将经由sdeexport备份的数据文件恢复到ArcSDE Server中。

  这一方式的缺点在于不能一次备份完整的空间数据库。但是也有个明显的优点,在于通过sdeexport和sdeimport工具,可以将空间数据在不同的关系型数据库管理系统(RDBMS)之间进行移植。

1. 备份全部记录

使用sdeexport命令的缺省方式即可,比如:

(1) 将指定的图层备份到备份文件

sdeexport -o create -l dcxq,shape -f d:\dcxq.exp -i jerry_oracle -u sde -p sde

就是将名为jerry_oracle的sde服务(ArcSDE for oracle8i)中的指定图层“dcxq”按缺省方式备份到文件d:\dcxq.exp中。

(2) 利用操作系统命令,拷贝备份文件到目标服务器上

(3) 将备份文件恢复至目标RDBMS中

 

sdeimport -o create -l newDcxq,shape -f d:\dcxq.exp -i jerry_sqlsvr -u sde -p sde

此操作将备份文件恢复到名为jerry_sqlsvr的sde服务(ArcSDE for SQLServer)中,图层名为:newDcxq。

2.备份部分记录

sdeexport命令中添加-w参数和一个条件选择表达式即可,比如:

(1) 将指定图层中满足条件的记录备份到备份文件

sdeexport -o create -l dcxq,shape -f d:\dcxq.exp -w xzqy = '徐汇区' -i jerry_oracle -u sde -p sde

就是将名为jerry_oracle的sde服务(ArcSDE for oracle8i)内的指定图层“dcxq”中所有"徐汇区"的人口调查小区备份到文件d:\dcxq.exp中。

(2) 利用操作系统命令,拷贝备份文件到目标服务器上

(3) 将备份文件恢复至目标RDBMS中

sdeimport -o create -l XHDcxq,shape -f d:\dcxq.exp -i jerry_sqlsvr -u sde -p sde

此操作将备份文件恢复到名为jerry_sqlsvr的sde服务(ArcSDE for SQLServer)中,图层名为:XHDcxq。

3.备份特定数据版本

sdeexport命令中添加-v参数和一个版本名称即可,比如:

(1) 将指定图层的特定版本备份到备份文件

sdeexport -o create -l dcxq,shape -f d:\dcxq.exp -V verAPR -i jerry_oracle -u sde -p sde

此操作将名为jerry_oracle的sde服务(ArcSDE for oracle8i)内的指定图层“dcxq”的verAPR版本备份到文件d:\dcxq.exp中。

(2) 利用操作系统命令,拷贝备份文件到目标服务器上

(3) 将备份文件恢复至目标RDBMS中

sdeimport -o create -l APRdcxq,shape -f d:\dcxq.exp -i jerry_sqlsvr -u sde -p sde

此操作将备份文件恢复到名为jerry_sqlsvr的sde服务(ArcSDE for SQLServer)中,图层名为:APRDcxq。

 

二、 整体空间数据库的备份和恢复

  ArcSDE空间数据库的整体备份和恢复,实质上很大程度上是其所在的数据库或者数据库对象的备份和恢复问题。当然完整的ArcSDE数据备份应当还包括 dbtune.sde,giomgr.defs,dbinit.sde 和 services.sde等文件。

 

  数据库的备份和恢复有很多种类。在不同的数据库管理系统中,更是千差万别。总体上,大都可以分为静态转储和动态转储两个类型。静态转储是在系统中无事务处理时进行的转储操作,因而这种方式得到的一定是一个数据一致性的副本。静态转储的优点是操作简单,保证数据一致性,但是缺点也很明显,转储操作必须等待用户事务结束才能进行,而新的事务必须等待转储操作结束才能执行,因此会降低数据库的可用性。动态转储是指转储操作与用户事务并发进行,转储期间允许数据库进行存取和修改操作,它不必等待所有运行的事务结束,也不会影响新事务的运行,但是无法保证副本中的数据正确、有效、完整。所以在动态转储期间,往往会建立日志文件。后备文件加上日志文件就可以把数据库恢复到正确的状态。

1. oracle数据库

(1) 两种归档模式(archive mode)

oracle有两中归档模式:NO ARCHIVELOG和ARCHIVELOG。在NO ARCHIVELOG模式(该模式为缺省模式)下的数据库操作不归档在线日志重做文件。当存储介质损坏时,NO ARCHIVELOG模式的数据库只能恢复到上一次的备份点上。ARCHIVELOG模式的数据库可以通过上一次的备份和归档日志重做文件相结合的方式,恢复到介质损坏之前的点上。

以NO ARCHIVELOG模式创建的Oracle数据库可以切换至ARCHIVELOG模式。

(2) 多种备份与恢复方式

oracle中的数据备份和恢复方式包括:脱机备份与恢复、逻辑备份与恢复、热备份与恢复。

* 脱机备份与恢复:脱机备份是一种静态转储技术,备份在数据库关闭、不工作的状态下进行。脱机备份包括两种实现方式:第一种是使用Oracle提供的工具Backup/Recover;第二种是利用操作系统的复制功能,复制数据文件,即:冷备份。

* 逻辑备份与恢复:逻辑备份与恢复是指将数据库、用户和表等对象的内容整个转出到一个二进制文件,然后在需要的时候通过转入恢复到原来的形式。这种方式可以备份整个数据库,指定用户和指定表的内容。

* 热备份与恢复:脱机备份和逻辑备份通常是用户不访问数据库时的静态备份操作。这些备份只保证数据备份前的一致性和完整性,不保证备份期间的数据一致性。为了保证数据的即时一致性,在备份数据的同时还需要备份日志文件。数据库运行在ARCHIVELOG方式下,同时作数据和日志文件的备份称为热备份。

(3) 实现步骤

选择使用何种备份方式,由具体的数据备份需求所决定。具体的Oracle数据库备份实现步骤需要参考Oracle相关文档,比如《Oracle8 Backup and Recovery Guide》。本实例采用Oracle中的逻辑备份,使用了exp和imp工具,以sde用户方式备份和恢复整体空间数据。

* 备份数据库:使用Oracle中的exp命令,以sde用户方式备份所有相关数据。

* 恢复数据库:使用Oracle中的imp命令,以sde用户方式恢复后备数据文件。

* 恢复ArcSDE系统文件:如果有必要,在恢复oracle数据之后,需要恢复安装ArcSDE的程序文件;另外还需要从备份机器上恢复dbtune,giomgr.defs,dbinit.sde,和services.sde文件。

2. SQLServer数据库

(1)备份和恢复方式

在MS SQL Server中,ArcSDE利用单独的用户数据库SDE(缺省名)来管理和组织空间数据。

SQLServer不仅可以在同一台服务器上备份和恢复数据库,还允许通过备份和恢复的方式在不同服务器之间很轻松地移动数据库。MS SQL Server也允许将一个服务器上的数据库备份恢复到另外一台服务器上。

如果要将数据库备份恢复到另外一台服务器上,两台服务器上的code page和排序方式必须相同。比如,不能把用二进制排序方式(Binary Sort order,BSO)建立的数据库恢复到一个配置为缺省排序方式(字典顺序,dictionary)的服务器上。当然,可以通过在master数据库中运行'sp_helpsort'存储过程设定服务器的排序方式。

数据库的备份操作同时备份了数据库的系统表,包括sysusers。当在不同的服务器上执行备份和恢复操作时,备份数据库中所包含的用户可能会和新的服务器上master数据库中sysxlogins表中包含的用户不同。这样的话,就无法登录到恢复后的数据库,知道更正并统一master数据库中sysxlogins表和恢复数据库中sysusers表的登录映射。要使上述两个表同步,需要运行"sp_change_users_login"存储过程。

(2)实现步骤

* 备份SDE数据库到备份文件:既可以使用T-SQL中的BACKUP语句,也可以使用企业管理器中的备份工具向导来完成SDE和其他空间数据库的备份。

* 将备份文件复制到目标服务器

* 将备份文件恢复到目标服务器:可以使用企业管理器中的恢复还原工具向导来完成SDE和其他空间数据库的恢复。

* 统一SDE用户登录映射

A. 两个服务器上都有SDE用户,但是两者的SDE用户具有不同的标识

当恢复SDE数据库至新的服务器后,sde数据库中的sde用户的SID与master数据库中dbo.sysxlogins表中的sde登录名的SID不同,比如:

Use sde

go

Select SID from sysusers where name = 'sde'

Use master

go

select SID from sysxlogins where name = 'sde'

 

SID

-----------------------------------------------------------

0x76695419BFAED41184FD00C04F8D0451

(1 row(s) affected)

 

SID

-----------------------------------------------------------

0xEDDFCA8E56B0D411850000C04F8D0451

(1 row(s) affected)

此时必须统一两个表中sde用户的SID标识,运行"sp_change_users_login" 存储过程,示例如下:

Use sde

go

sp_change_users_login 'update_one','sde','sde'

运行上述的SID查询来验证修改结果:

0xEDDFCA8E56B0D411850000C04F8D0451

0xEDDFCA8E56B0D411850000C04F8D0451

可以看出修改后两个表中sde用户的SID标识完全一致,此时就可以启动ArcSDE for SQLServer的服务来使用了。

B. 目标服务器上还没有SDE用户

这种情形是指目标服务器上还没有sde登录用户,此时执行上述的SID查询,结果如下:

Use sde

go

Select SID from sysusers where name = 'sde'

Use master

go

select SID from sysxlogins where name = 'sde'

SID

-----------------------------------------------------------

0x76695419BFAED41184FD00C04F8D0451

(1 row(s) affected)

SID

-----------------------------------------------------------

(0 row(s) affected)

要矫正这种情况,需要首先到目标服务器中添加sde登录用户,但是不要将sde数据库的权限授予sde用户。添加登录用户,使用"sp_addlogin"存储过程和在企业管理器中使用登录管理工具。比如:

sp_addlogin 'sde','go','sde'

然后需要运行 "sp_change_users_login" 存储过程来统一master内dbo.sysxlogins表和恢复后用户数据库内sysusers表中的sde用户SID标识。

use sde

go

sp_change_users_login 'update_one','sde','sde'

最后,可以执行SID查询来验证SID的一致性:

Use sde

Go

Select SID from sysusers where name = 'sde'

Use master

Go

select SID from sysxlogins where name = 'sde'

SID

-----------------------------------------------------------

0xF6DFCA8E56B0D411850000C04F8D0451

(1 row(s) affected)

SID

-----------------------------------------------------------

0xF6DFCA8E56B0D411850000C04F8D0451

(1 row(s) affected)

经过SDE用户的SID的统一之后,就可以启动ArcSDE服务或者使用直接连接(direct connection)方式使用恢复后的空间数据了。

 

 

  • 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、付费专栏及课程。

余额充值