ArcGIS Engine+分布式数据库操作

简介: 我们知道Geodatabase的分布式数据库可以在线也可以离线,而在线和离线的接口是不同的,这是因为两者的操作过程不一样,我们看一下两者的区别:                                                                             ...

我们知道Geodatabase的分布式数据库可以在线也可以离线,而在线和离线的接口是不同的,这是因为两者的操作过程不一样,我们看一下两者的区别:
                  

                                
          
                                        在线

 



                                                                                                                      离线




通过这4张图很清楚的说明了原理(其中每一种方式又分为局域网和互联网)

重要的接口:

GeoDataServer  代表了一个数据库的连接,这句话可能不好理解,但是通过代码,也许会明白:

public IGeoDataServer InitGeoDataServerFromFile(String path)

{

    // Create the GeoDataServer and cast to the the IGeoDataServerInit interface.

    IGeoDataServer geoDataServer = new GeoDataServerClass();

    IGeoDataServerInit geoDataServerInit = (IGeoDataServerInit)geoDataServer;

    geoDataServerInit.InitFromFile(@"C:\arcgis\ArcTutor\DatabaseServers\hazards.gdb");

    return geoDataServer;

}

在离线方式下,我们的数据同步是通过导入,导出,而导入,导出这些方法由此接口提供,看下面的例子:

public void ExportReplicaDataChanges(IGeoDataServer sourceGDS, String replicaName,

    String outputDirectory)

{

    try

    {

        // Set the export options.

        GDSExportOptions gdsExportOptions = new GDSExportOptions();

        gdsExportOptions.ExportFormat = esriGDSExportFormat.esriGDSExportFormatXml;

        gdsExportOptions.Compressed = true;

        gdsExportOptions.BinaryGeometry = false;



        // Export the data changes. Note: The replica must be in a Sending Data State.

        IGDSData gdsData = sourceGDS.ExportReplicaDataChanges(replicaName,

            gdsExportOptions, esriGDSTransportType.esriGDSTransportTypeUrl,

            esriExportGenerationsOption.esriExportGenerationsAll, false);



        // Force deletion of folder and contents if they exist.

        if (Directory.Exists(outputDirectory))

        {

            Directory.Delete(outputDirectory, true);

        }



        // Create the output folder.

        Directory.CreateDirectory(outputDirectory);



        // Get the compressed data changes document from the URL to the local output directory.

        if (gdsData.TransportType == esriGDSTransportType.esriGDSTransportTypeUrl)

        {

            string fileName = System.IO.Path.GetFileName(gdsData.URL);

            string outputFileName = System.IO.Path.Combine(outputDirectory, fileName)

                ;

            WebClient wc = new WebClient();

            wc.DownloadFile(gdsData.URL, outputFileName);

            wc.Dispose();

        }

        else

        {

            // The file has been embedded because there is no output directory set on ArcGIS Server.

            Console.WriteLine("Server is not configured with a virtual directory.");

        }

    }

    catch (COMException comExc)

    {

        throw new Exception(String.Format(

            "Exporting data changes errored: {0}, Error Code: {1}", comExc.Message,

            comExc.ErrorCode), comExc);

    }

    catch (Exception exc)

    {

        throw new Exception(String.Format("Exporting data changes errored: {0}",

            exc.Message), exc);

    }

}

而在在线方式下,用ReplicatonAgent接口

ReplicatonAgent 接口就是用来实现在线方式下的同步

public void SynchronizeReplica(IGeoDataServer parentGDS, IGeoDataServer childGDS,

    String replicaName, esriReplicationAgentReconcilePolicy conflictPolicy,

    esriReplicaSynchronizeDirection syncDirection, Boolean columnLevel)

{

    try

    {

        // Iterate through the replicas of the parent geodata server.

        IGPReplicas gpReplicas = parentGDS.Replicas;

        IGPReplica parentReplica = null;

        for (int i = 0; i < gpReplicas.Count; i++)

        {

            // See if the unqualified replica name matches the replicaName parameter.

            IGPReplica currentReplica = gpReplicas.get_Element(i);

            String currentReplicaName = currentReplica.Name;

            int dotIndex = currentReplicaName.LastIndexOf(".") + 1;

            String baseName = currentReplicaName.Substring(dotIndex,

                currentReplicaName.Length - dotIndex);

            if (baseName.ToLower() == replicaName.ToLower())

            {

                parentReplica = currentReplica;

                break;

            }

        }



        // Check to see if the parent replica was found.

        if (parentReplica == null)

        {

            throw new ArgumentException(

                "The requested replica could not be found on the parent GDS.");

        }



        // Iterate through the replica of the child geodata server.

        gpReplicas = childGDS.Replicas;

        IGPReplica childReplica = null;

        for (int i = 0; i < gpReplicas.Count; i++)

        {

            // See if the unqualified replica name matches the replicaName parameter.

            IGPReplica currentReplica = gpReplicas.get_Element(i);

            String currentReplicaName = currentReplica.Name;

            int dotIndex = currentReplicaName.LastIndexOf(".") + 1;

            String baseName = currentReplicaName.Substring(dotIndex,

                currentReplicaName.Length - dotIndex);

            if (baseName.ToLower() == replicaName.ToLower())

            {

                childReplica = currentReplica;

                break;

            }

        }



        // Check to see if the child replica was found.

        if (childReplica == null)

        {

            throw new ArgumentException(

                "The requested replica could not be found on the child GDS.");

        }



        // Synchronize the replica.

        IReplicationAgent replicationAgent = new ReplicationAgentClass();

        replicationAgent.SynchronizeReplica(parentGDS, childGDS, parentReplica,

            childReplica, conflictPolicy, syncDirection, columnLevel);

    }

    catch (COMException comExc)

    {

        throw new Exception(String.Format(

            "Create replica errored: {0}, Error Code: {1}", comExc.Message,

            comExc.ErrorCode), comExc);

    }

    catch (Exception exc)

    {

        throw new Exception(String.Format("Create replica errored: {0}", exc.Message)

            , exc);

    }

相关文章
|
5月前
|
SQL 关系型数据库 MySQL
乐观锁在分布式数据库中如何与事务隔离级别结合使用
乐观锁在分布式数据库中如何与事务隔离级别结合使用
|
3月前
|
SQL 关系型数据库 MySQL
乐观锁在分布式数据库中如何与事务隔离级别结合使用
乐观锁在分布式数据库中如何与事务隔离级别结合使用
|
26天前
|
Cloud Native 关系型数据库 分布式数据库
PolarDB 分布式版 V2.0,安全可靠的集中分布式一体化数据库管理软件
阿里云PolarDB数据库管理软件(分布式版)V2.0 ,安全可靠的集中分布式一体化数据库管理软件。
|
5月前
|
存储 SQL 分布式数据库
OceanBase 入门:分布式数据库的基础概念
【8月更文第31天】在当今的大数据时代,随着业务规模的不断扩大,传统的单机数据库已经难以满足高并发、大数据量的应用需求。分布式数据库应运而生,成为解决这一问题的有效方案之一。本文将介绍一款由阿里巴巴集团自主研发的分布式数据库——OceanBase,并通过一些基础概念和实际代码示例来帮助读者理解其工作原理。
452 0
|
2月前
|
关系型数据库 分布式数据库 数据库
PostgreSQL+Citus分布式数据库
PostgreSQL+Citus分布式数据库
71 15
|
3月前
|
SQL 关系型数据库 分布式数据库
Citus 简介,将 Postgres 转换为分布式数据库
【10月更文挑战第4天】Citus 简介,将 Postgres 转换为分布式数据库
118 4
|
3月前
|
SQL NoSQL MongoDB
一款基于分布式文件存储的数据库MongoDB的介绍及基本使用教程
一款基于分布式文件存储的数据库MongoDB的介绍及基本使用教程
56 0
|
5月前
|
存储 缓存 负载均衡
【PolarDB-X 技术揭秘】Lizard B+tree:揭秘分布式数据库索引优化的终极奥秘!
【8月更文挑战第25天】PolarDB-X是阿里云的一款分布式数据库产品,其核心组件Lizard B+tree针对分布式环境优化,解决了传统B+tree面临的数据分片与跨节点查询等问题。Lizard B+tree通过一致性哈希实现数据分片,确保分布式一致性;智能分区实现了负载均衡;高效的搜索算法与缓存机制降低了查询延迟;副本机制确保了系统的高可用性。此外,PolarDB-X通过自适应分支因子、缓存优化、异步写入、数据压缩和智能分片等策略进一步提升了Lizard B+tree的性能,使其能够在分布式环境下提供高性能的索引服务。这些优化不仅提高了查询速度,还确保了系统的稳定性和可靠性。
107 5
|
5月前
|
运维 安全 Cloud Native
核心系统转型问题之分布式数据库和数据访问中间件协作如何解决
核心系统转型问题之分布式数据库和数据访问中间件协作如何解决
|
5月前
|
Cloud Native 关系型数据库 分布式数据库
中国金融分布式数据库,阿里云双料冠军!
中国金融分布式数据库,阿里云双料冠军!
90 7