ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

时间:2024-01-15 14:54:44

平台软件:ARCIGS10.1 ,SQL Server2008R2

目的:了解客户端在连接arcgis 空间地理数据库后,地理数据库会做些什么样的初始化工作

准备工作:

1.准备好数据库日志文件查看工具,通过日志查看工具可以查看对数据库的详细加载过程,本文采用ApexSQL Log 2013工具,目前该工具有试用版,挺好用的。这个

工具可以用来做数据库恢复。

2.准备好一份空间数据库

前提条件:

1.本测试没有包含采用版本机制的情况

2.为了尽量保证测试的单纯性,数据库全部放在本地,没有其他任何人连接。

3.测试连接采用了winform的桌面客户端,没有测试WEB端或手机端的连接,这个以后再测。

步骤:

启动过程:


1.启动一个客户端,并连接地理数据库,通过ApexSQL Log分析数据库的.ldf文件,得出如下记录:(客户端登录连接时间为15:41分)

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

通过上述操作列表可以看出,地理数据库后台先后操作了SDE_object_ids、SDE_process_information、SDE_state_locks、SDE_table_locks四张表。分别执行Update与Insert操作,这些操作

可以理解为:创建连接——保存连接信息——初始化状态表——初始化要素加载表

这四张表在ARCGIS的帮助文档中可以看到其主要含义:(http://help.arcgis.com/zh-cn/arcgisserver/10.0/help/arcgis_server_java_help/index.html#//002p00000085000000

在本次测试中,当发生连接时这四张表的数据如下:

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

此处,数据库中插入的记录为:

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

可以看到类型为connection

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

这张表主要记录连接者的信息,在退出后,对应的记录将会被删除

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

数据库中的记录为:

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

可以看出四个地理要素都是共享模式(S)

通过registration_id字段,可以在sde_table_registry中查出初始化了哪些地理要素,在这里10,23,24,25都是对应的地理要素的ID

ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

从这个表可以详细看出加载了哪些图层。

退出过程:


ARCGIS10.1 GeoDatabase深入理解:客户端连接与退出地理数据库时系统表的初始化

从退出来看,执行了逆向的删除操作,从表锁定记录中、状态记录中、客户端进程中删除已经断开的连接信息。

只有SDE_object_ids表中的数据没有删除,每次只执行了更新操作。

总结


通过对加载过程与退出过程的了解,知道了地理数据库的几张表的协同关系以及他们所起的作用。