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


    平台软件:ARCIGS10.1 ,SQL Server2008R2

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

    准备工作:

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

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

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

    前提条件:

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

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

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

    步骤:

    启动过程:


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

    image

    通过上述操作列表可以看出,地理数据库后台先后操作了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

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

    image

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

    image

    可以看到类型为connection

    image

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

    image

    数据库中的记录为:

    image

    image

    image

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

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

    image

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

    退出过程:


    image

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

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

    总结


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

  • 相关阅读:
    TOP 100 SOFTWARE VENDORS (ZZ)
    数列总结函数——取余分析
    科克曼女生问题
    约瑟夫问题(猴子选王)——多种解法
    乒乓球与羽毛球不同发球规则下选手的胜率——概率论+程序分析
    Codeblocks快捷键
    常用陌生快捷键
    Dev使用技巧
    vueDemo补充
    vueDemo
  • 原文地址:https://www.cnblogs.com/hanchan/p/3611752.html
Copyright © 2020-2023  润新知