arcgissde数据库
‘壹’ ArcSDE创建企业级数据库
ArcSDE创建企业级数据库
在ArcCatalog或者ArcMap中打开ArcToolBox工具箱。
在工具箱中,找到创建企业级地理数据库工具,依次为数据管理工具→地理数据库管理→创建企业级地理数据库
‘贰’ 如何配置Oracle数据库使之成为ArcSDE数据库
Oracle数据库本身虽然具备空间数据库的支持组件,但是为了使用ArcSDE,还必须进行配置。可以安装ArcSDE for
Oracle10g并利用其配置工具进行配置。其安装过程不再赘述,因为主要都是点击下一步而已。下面主要讲解其配置流程。实际上,配置有两种方式。第一
种方式是使用VerifyOra工具(点击菜单“开始/所有程序/ArcGIS/ArcSDE/ArcSDE for Oracle10gR2 Post
Installation”);第二种方式是使用编程的方式。
以下先讲解第一种方式,即使用VerifyOra工具配置数据库的过程(实际上安装完ArcSDE for
Oracle之后会自动启动该工具)。为了叙述和测试的方便,首先使用Oracle数据库配置工具新建一个数据库,以后的测试都将使用该数据库。需要注意
的是,这样配置数据库仅用于学习之用,如果要用做生产数据库,那么必须对所有参数进行优化配置。
1、启动Oracle数据库配置向导(开始运行中输入dbca回车),并选择“创建数据库”之后点击“下一步”按钮
2、在模板列表中选择“一般用途”,并点击“下一步”按钮
3、在全局数据库名中输入“dbname1”,并点击“下一步”按钮
4、直接点击“下一步”按钮
5、在口令和确认口令中输入“password1”,直接点击“下一步”按钮
6、直接点击“完成”按钮
7、在确认对话框中直接点击“确定”按钮
8、系统随即开始创建数据库dbname1
9、数据库创建完毕后会显示数据库信息,点击退出按钮即完成数据库创建。
10、启动VerifyOra工具,系统显示配置向导,选择“Custom”模式,然后点击“下一步”按钮。。
11、系统显示选项对话框。“Define SDE User
Environment”即创建空间数据库管理员账号、表空间等环境信息。“Repository
Setup”即配置空间数据库,前提是必须存在SDE账号以及表空间。“Authorize
ArcSDE”即给空间数据库授权,否则空间数据库将不可使用。“Create ArcSDE
Service”即创建ArcSDE服务。可以看到,每一种选项都以前面所有配置为前提。这里为了学习的方便,全部选项都选择上,并点击“下一步”按钮。
12、系统显示数据库连接对话框。在“Net service
name”中输入数据库的网络名称,例如输入“dbname1”。在“Sys user
password”中输入sys用户的密码,例如输入“password1”。然后点击“下一步”按钮。
13、系统显示用户名和表空间配置对话框。在“SDE user
password”中录入设置的sde用户密码。在“Default
tablespace”中输入默认表空间的名称。sde用户是空间数据库的管理员账号,用户名称不能修改,但是这个用户的密码和默认表空间名称以及表空间
数据文件的名称和位置是可以设置的。录入所有信息后点击“下一步”按钮,系统开始配置空间数据库,配置完成后系统将依次显示“The SDE
tablespace was successfully created”、“The SDE user was successfully
created”等信息,依次点击“确定”按钮即可。
14、用户和表空间配置完毕之后,系统显示配置文件选项,直接点击“下一步”按钮即可。
15、系统显示调优配置文件选项,直接点击“下一步”按钮即可。
16、系统显示空间库配置选项,分别输入sde用户的密码以及数据库网络名,然后点击“下一步”按钮。空间库配置完毕后,系统
会显示配置完成的信息,并询问是否打开详细日志文件。一般配置成功的话,无需查看详细信息。如果配置失败,可以查看详细原因。
17、系统显示授权配置向导。必须在空间库配置成功的前提下才能进行授权。直接点击“下一步”按钮即可。
18、选择适当的授权方式。这里我们选择第二种方式,即通过授权文件来完成注册过程。然后点击“下一步”按钮。系统显示配置文
件选择对话框,点击“Browse”按钮找到授权文件(*.ecp),点击“下一步”按钮,确认授权信息,并点击“完成”按钮即可完成授权。
19、系统启动服务配置对话框。依次录入服务名称(Service name)、端口号和协议(Service port
number)、SDE用户密码(SDE user password)、Oracle实例名(ORACLE SID)、服务器名称(Server
name)。服务名称用于为服务命名,可以在Windows服务中看到该名字的服务。如果服务名录入“esri_sde_db1”,那么可以在
Windows服务中看到名为“ArcSde
Service(esri_sde_db1)”的服务。Oracle实例名请参照图1.3中的SID设置。录入所有信息后,点击“下一步”按钮。系统显示
完成信息,直接点击“完成”按钮即可。
以上为第一种方式,即使用工具来配置ArcSde数据库和服务。以下将详解如何通过命令的形式配置空间数据库。注意,如果需要配置服务,请参照sdeservice命令的参考信息。
1、创建SDE表空间。命令如下:
create tablespace sde datafile 'sde.dbf' size 400M extent management local uniform size 512K;
2、创建SDE用户,并授予适当的权限。命令如下:
grant execute on dbms_pipe to public;
grant execute on dbms_lock to public;
create user sde identified by sde default tablespace sde temporary tablespace temp;
grant CREATE SESSION to sde;
grant CREATE TABLE to sde;
grant CREATE PROCEDURE to sde;
grant CREATE SEQUENCE to sde;
grant CREATE TRIGGER to sde;
grant CREATE TYPE to sde;
grant CREATE LIBRARY to sde;
grant CREATE PUBLIC SYNONYM to sde;
grant CREATE OPERATOR to sde;
grant CREATE INDEXTYPE to sde;
grant DROP PUBLIC SYNONYM to sde;
grant UNLIMITED TABLESPACE to sde;
grant CREATE ANY VIEW to sde;
grant SELECT ANY TABLE to sde;
3、配置空间数据库。命令如下:
sdesetup -o install -d ORACLE10G -u sde -p sde@dbname1 -l server92.ecp -N
‘叁’ ArcSDE是ArcGIS与关系数据库之间的GIS通道,主句话的意思是什么啊
比如说关系型数据库是sql
Server,你的gis数据实际上还是存储在SQL
Server中的表,而sde起的作用是,一个通道,gis数据通过sde这个通道,按照规范的空间数据格式,存储在SQL
Server表中。
‘肆’ arcgis sde10.2需要安装什么数据库客户端
Arcgis支持三种主流数据库Oracle Sqlserver Postgresql,第三个是来源的,根据自己需要选择吧!
‘伍’ 怎么对ArcSDE数据库的要素类进行批量重建空间索引
在我们遇到很多有关于性能的问题,我们一般建议用户重新常见空间索引,那么如果用户一个库里面有几十个甚至上百个空间索引,那么该怎么处理呢?
ArcGIS10.1版本
RebuildIndexes:(这个功能只有ArcGIS10.1才有的)
这个功能主要是对用户进行大范围数据编辑,在原有数据基础上做大量的数据加载或者数据删除后,为了提高数据性能,进行的操作。其实听到这里有点老生常谈,我们原来的方法也是一个图层一个图层的进行重建索引,但是这个功能可以 批量的重建索引 ,而且及支持属性索引也支持空间索引,支持系统表以及版本的增量表的重建索引,比较方便。
ArcGIS10之前的版本
但是对ArcGIS10以及之前的版本并没有批量重建索引的办法,我们只能另辟蹊径了。
1:使用sde命令行的方法
我们可以使用sde命令,load_only_io和normal_io进行切换来进行空间索引的重建,具体请看帮助。
Switch between load only and normal I/O modes.
To modify a feature class's input/output mode, use the load_only_io and normal_io operations.
You must be the owner of the feature class to change it from normal I/O to load-only I/O mode.
It is recommended that you do not place a versioned feature class that uses binary storage in load only I/O mode because, when you switch back to normal I/O mode, the spatial index will be calculated on a versioned representation of the features. This representation may not match what is stored in the nonversioned f table to which the index gets applied. If this is the case, an error is returned.
When the sdelayer command is used to create a layer (i.e., if the register or add operations are used), the resultant feature class is automatically in normal I/O mode. The load-only I/O mode is provided to make bulk data loading processes more efficient. Use load-only mode when performing large inserts to avoid the continuous update of the feature class's indexes.
For feature classes that use a spatial grid index (SDEBINARY, SDELOB, WKB_GEOMETRY, or feature classes in DB2), if the grid fields are updated while the feature class is in load-only I/O mode, the spatial index is rebuilt with the new grid sizes when you reset the feature class to normal I/O mode. While rebuilding the spatial index table, the feature class is inaccessible to other users. Note: You can change the grid sizes while the feature class is in normal or load-only I/O mode. If you reset spatial indexes while the feature class is in normal I/O mode, the indexes on the spatial index table are dropped while the spatial index is being re-created..
When the feature class is in normal I/O mode, the envelope is automatically updated whenever a feature that extends the current envelope is added. The envelope is not updated while the feature class is in load-only I/O mode but is recalculated to the full extent when the feature class is reset to normal I/O mode.
These examples show the parcels feature class being moved into load only mode then back to normal I/O mode.
sdelayer -o load_only_io -l victoria,parcels -u av -p mo -i esri_40
sdelayer -o normal_io -l victoria,parcels -u av -p mo -i esri_40
When the feature class is returned to normal I/O mode, the spatial index table and database indexes are rebuilt. If the operation does not complete successfully for any reason, the feature class is left in load-only I/O mode.
When a feature class is in load-only I/O mode, the unique index is removed from the feature class's spatial column. When the index is absent, it is possible to enter nonunique values into the spatial column with an application not created with the ArcSDE C- or Java application programming interface (API). Therefore, no applications besides ArcSDE or applications created with the ArcSDE C- or Java API should ever update the spatial column. Database administrators should be aware of the increased vulnerability of the spatial column when the feature class is in load-only I/O mode.
我知道很多朋友肯定没有认真看上面的英文解释,但是没有关系,大家只需要知道,如果我们使用load_only_io模式,就是删除空间索引,我们使用normal_io模式就是创建空间索引就可以了。
那么知道了这两个模式,我们在对该模式做一个延伸介绍
注意:一般情况下,如果我们业务有变更的情况,比如我们插入一条记录,如果是使用ArcGIS客户端或者相关API进行操作,除了我们新添加一条记录外,我们还同步的对空间索引进行更新,但是如果我们业务上有批量更新的情况,那么我们除了变更数据表,而且我们还要同步的批量变更空间索引信息,这样对性能会有一些影响。那么我们就可以在批量变更之前,将数据切换到load_only_io模式,然后进行批量变更,等变更业务彻底完成之后,再切换到normal_io模式,以达到重建索引的目的。
那么对数据量比较多的要素类,我们可以使用sde命令编写批处理文件来对数据进行批量创建空间索引
@echo OFF
pause "按任意键开始"
sdelayer -o load_only_io -l quxian,shape -i 5151 -s 192.168.220.165 -u sde -p sde
echo "图层quxian已经删除了空间索引"
sdelayer -o normal_io -l quxian,shape -i 5151 -s 192.168.220.165 -u sde -p sde
echo "图层quxian已经创建了空间索引"
...
sdelayer -o load_only_io -l quxian1,shape -i 5151 -s 192.168.220.165 -u sde -p sde
echo "图层quxian1已经删除了空间索引"
sdelayer -o normal_io -l quxian1,shape -i 5151 -s 192.168.220.165 -u sde -p sde
echo "图层quxian1已经创建了空间索引"
pause "按任意键结束"
将以上数据保存为.bat文件,用的时候直接运行即可。
2:使用python脚本重建索引
如果大家留心会发现一个问题,虽然上面使用sde命令可以对要素类进行批量重建索引,但是它仍然需要用户指定特定的要素类名称,那么如果及时个甚至上百个要素类,对用户来说仍然是一个梦魇,那么我们使用python脚本就可以很轻松的实现这个功能。
我们使用Python脚本可以对某个SDE连接下的数据集或者要素类进行遍历,然后对遍历的要素类使用GP工具,该GP工具可以删除和重建空间索引,就是这么简单
from arcpy import *
env.workspace=r'Database Connections\Connection to 192.168.100.111.sde'
for dataset in ListDatasets():
for fc in ListFeatureClasses("","ALL",dataset):
RemoveSpatialIndex_management(fc)
AddSpatialIndex_management(fc)
执行过程中,我们可以看到右边的信息框的执行过程。
‘陆’ arcgis中怎么给sde数据库扩容
在arctoolbox中选择data management tools工具中的projection and transformation工具中,选择define projection 工具,设置自己想要的投影坐标就行了
‘柒’ 怎样把ArcGIS图层数据添加在sde数据库中(SQL Server)
ArcCatalog中,在sde连接上右键,import-->feature class就行
或者使用toolbox中的featureClass to featureclass
‘捌’ 空间数据库引擎ArcSDE
空间数据库引擎:ArcSDE9.0(arc spatial database engine);此软件被用作系统后台(Server),其优势在于能按照用户需求合理地管理大规模甚至超大规模的空间数据库,为系统前端提供高效的空间数据和复杂的空间分析服务。
选择空间数据库引擎SDE作为空间数据库管理系统,是一套管理空间数据并提供访问这些数据接口的软件,通过ArcSDE可以把地理空间数据应用到商用的关系型数据库中,SDE融入DBMS后,提供了对空间数据进行高效率操作的接口,大量用户可以同时针对同一数据进行操作,更重要的是ArcSDE客户和服务器之间的通讯建立在TCP/IP协议上,这使得ArcSDE不但能满足局域网的应用,而且能满足远程网的应用。
通过ArcSDE,能够管理具有数百万空间要素的大型空间数据集。ArcSDE对各级企业均能适用,这归功于其在客户与服务器间协同处理。ArcSDE通过TCP/IP协议,提供网络上的开放数据访问;同时,ArcSDE可运行在不同的操作系统环境中,如UNIX,Microsoft Windows的客户端与服务器端。
为了实现以关系数据库管理系统(Oracle)为基础的空间数据管理,需要使用空间数据库引擎。良好的空间数据库引擎能够为数据库的应用系统开发提供高性能的支持。ESRI公司的ArcSDE for Or-acle 是一个基于Oracle的空间数据库引擎,它的空间数据管理高效而稳定,将作为本项目综合数据库的必须软件产品之一。其特点:
(1)对地理数据的开放式系统访问
ArcSDE利用开放系统结构,使得地理数据易于获得,可以把地理数据的管理与使用同其他传统的多媒体数据库合并到一个平滑的计算机环境中。利用ArcSDE的开放性,用户可以进行从简单到复杂的空间数据分析,从几个到许多地理特征的提取,访问超大规模的数据库,高效完成各种复杂任务。
(2)进行高效查询分析
ArcSDE提供一组可靠的几何处理与空间分析功能,通过此功能确定各地理实体间的相互关系,如相交于一点、共一条边界、共一个区域或一个实体包含另一个实体。而且还可以把空间分析嵌入到一个非GIS的应用程序中去。
(3)理想的空间对象模型
ArcSDE把线特征表示成一条不能自相交的线,或只能在终点相交的线;面特征表示成一个简单的多边形或多边形组合。空间对象类型有点、点集、串、线串、环、多边形、环纹多边形(donut polygon)以及网络数据,一个组合数据集称为一个层。层是具有相同形式对象类型的一组地理特征,地理特征通过图层这种空间连续策略进行索引,提高数据管理效率。
(4)快速实现过程
ArcSDE对于复杂空间查询的处理的效率体现在对次要特征(Subsecond Feature)的检索上,快速访问与检索是在C/S模式上实现的,客户端主要是响应空间分析操作,服务器则进行数据搜索和检索。这种互操作处理方法使得动态空间叠加成为可能,当大量增加客户端的时候,利用这种处理可以把客户机带来的性能下降降到最小。
(5)其他
客户端可以通过TCP/IP协议访问Arc/Info数据,不用通过传统的直接挂到数据库所在的磁盘上进行访问,这样系统就可以建立在广域网上,数据分布将不受地域限制。同时允许将一部分数据放在RDBMS中,另一部分数据以传统Arc/Info数据格式保存。而客户端的应用将以同一种方式进行访问,即数据源的不同对客户而言是完全透明的。
ArcSDE本身并没有专用数据库,而是通过与其他通用的DBMS的集成来管理空间数据。根据DBMS的类型,ArcSDE与DBMS的集成可分为两种:①与传统的关系型数据库管理系统(RDBMS)的集成,由于传统的RDBMS不支持数据类型的扩展,无法管理空间数据,只能通过ArcSDE对空间数据和空间操作进行解释和管理。②与面向对象关系数据库(OORDMS)的集成。由于面向对象的关系支持新的数据类型和函数的扩展,ArcSDE可以直接在数据库中定义空间数据类型和空间函数。于是可以通过基于SQL的函数对空间数据进行操作,并在数据库层次建立空间索引。
‘玖’ arcgis 的sde和doc文件存放在哪
首先你要明白arcsde是什么,ArcSDE是空间数据库引擎,也可以说是一个中间件,它的作用是GIS客户端(arcmap,arctatalog等)访问或操作空间数据库时的一个通道,ArcSDE本身不会存储文件,而是将空间信息存储在dbms中(如sql server,oracle,db2等)。
加载硬盘上的空间数据到arcsde上有什么作用?
客户端访问arcsde服务(默认是5151),arcsde会连接DMBS,但不会给你返回DMMS中的表,而是给你返回arcgis中Geodatabase定义类型中的FeatureClass、FeatureDataset, Table等,所以,可以说不管你用的是什么DBMS,只要通过arcsde访问,访问接口都是一样的,这样,用户就不要考虑用不同的接口访问不同的数据库类型。
是不是加载到arcsde以后还要进行操作加载的关系数据库中。然后就可以通过关系数据库管理那些空间数据。
你只需要访问arcsde,不需要操作关系数据库。你可以不管数据库中存了什么,你的客户端访问时,如用ArcCatalog访问时,输入server,port,database,sdeuser,sdepassword,就可以访问了。
最后,如果你还没明白,你安装并配置ArcSDE后,以(ArcSDE + SQL SERVER为例)你可以打开数据库中的sde数据库,你可以看到里面存储了很多表,这些表管理并存储了所有空间数据库的内容及关系,如果你新建或删除一个图层(FeatureClass) ,你不需要去操作SQL SERVER,因为ArcSDE它会操作SQL SERVER,并在SQLSERVER中进行新建或删除处理,你没必要知道ArcSDE是怎么操作SQL SERVER的,你只需要知道如何访问ArcSDE(Geodatabase),而访问ArcSDE的方法却很简单,ArcGIS等软件都可以访问,输入一些参数(server,port,database,sdeuser,sdepassword)就OK了。
‘拾’ arcgis,sde连接空间数据库,成功连接一段时间后,莫名其妙的会自动断开,不知道为什么,求大神指教
这个是arcsde服务器安装中的设定,默认一段时间无操作自动断开,改掉就好了,当然这个只适合自己练习,真实空间服务器需要有这样的设定。