ArcGIS Pro SDK (八)地理数据库 1 地理数据库和数据存储

ArcGIS Pro SDK (八)地理数据库 1 地理数据库和数据存储

文章目录

  • [ArcGIS Pro SDK (八)地理数据库 1 地理数据库和数据存储](#ArcGIS Pro SDK (八)地理数据库 1 地理数据库和数据存储)
    • [1 打开给定路径的文件地理数据库](#1 打开给定路径的文件地理数据库)
    • [2 使用连接属性打开企业级地理数据库](#2 使用连接属性打开企业级地理数据库)
    • [3 使用 sde 文件路径打开企业级地理数据库](#3 使用 sde 文件路径打开企业级地理数据库)
    • [4 从工程项获取地理数据库](#4 从工程项获取地理数据库)
    • [5 从连接文件获取数据库连接属性](#5 从连接文件获取数据库连接属性)
    • [6 从要素图层获取地理数据库](#6 从要素图层获取地理数据库)
    • [7 执行 SQL 语句](#7 执行 SQL 语句)

环境:Visual Studio 2022 + .NET6 + ArcGIS Pro SDK 3.0

1 打开给定路径的文件地理数据库

csharp 复制代码
public async Task OpenFileGDB()
{
    try
    {
        await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
            () =>
            {
                // 打开一个文件地理数据库。如果文件夹存在且包含有效的地理数据库,这将打开该地理数据库。
                using ( Geodatabase geodatabase = new Geodatabase(new FileGeodatabaseConnectionPath(new Uri(@"C:\Data\LocalGovernment.gdb"))))
                {
                    // 使用地理数据库。
                }
            });
    }
    catch (GeodatabaseNotFoundOrOpenedException exception)
    {
        // 处理异常。
    }
}

2 使用连接属性打开企业级地理数据库

csharp 复制代码
public async Task OpenEnterpriseGeodatabase()
{
    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            // 打开一个非版本化的 SQL Server 实例。
            DatabaseConnectionProperties connectionProperties = new DatabaseConnectionProperties(EnterpriseDatabaseType.SQLServer)
            {
                AuthenticationMode = AuthenticationMode.DBMS,

                // testMachine 是运行该实例的计算机,testInstance 是 SQL Server 实例的名称。
                Instance = @"testMachine\testInstance",

                // 假设在 testInstance 上已创建一个名为 LocalGovernment 的数据库,并且已在该数据库上启用地理数据库。
                Database = "LocalGovernment",

                // 假设已创建一个名为 gdb 的登录名,并为其创建了具有所需权限的相应架构。
                User = "gdb",
                Password = "password",
                Version = "dbo.DEFAULT"
            };

            using (Geodatabase geodatabase = new Geodatabase(connectionProperties))
            {
                // 使用地理数据库
            }
        });
}

3 使用 sde 文件路径打开企业级地理数据库

csharp 复制代码
public async Task OpenEnterpriseGeodatabaseUsingSDEFilePath()
{
    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            using (Geodatabase geodatabase = new Geodatabase(new DatabaseConnectionFile(new Uri("path\\to\\sde\\file\\sdefile.sde"))))
            {
                // 使用地理数据库。
            }
        });
}

4 从工程项获取地理数据库

csharp 复制代码
public async Task ObtainingGeodatabaseFromProjectItem()
{
    IEnumerable<GDBProjectItem> gdbProjectItems = Project.Current.GetItems<GDBProjectItem>();

    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            foreach (GDBProjectItem gdbProjectItem in gdbProjectItems)
            {
                using (Datastore datastore = gdbProjectItem.GetDatastore())
                {
                    // 不支持的存储类型(非文件地理数据库和非企业级地理数据库)将是 UnknownDatastore 类型
                    if (datastore is UnknownDatastore)
                        continue;

                    Geodatabase geodatabase = datastore as Geodatabase;
                    // 使用地理数据库。
                }
            }
        });
}

5 从连接文件获取数据库连接属性

csharp 复制代码
DatabaseConnectionFile connectionFile = new DatabaseConnectionFile(new Uri("path\\to\\sde\\file\\sdefile.sde"));
DatabaseConnectionProperties connectionProperties = DatabaseClient.GetDatabaseConnectionProperties(connectionFile);

// 现在你可以,例如,在使用连接属性打开地理数据库之前更改用户名和密码

6 从要素图层获取地理数据库

csharp 复制代码
public async Task ObtainingGeodatabaseFromFeatureLayer()
{
    IEnumerable<Layer> layers = MapView.Active.Map.Layers.Where(layer => layer is FeatureLayer);

    await ArcGIS.Desktop.Framework.Threading.Tasks.QueuedTask.Run(
        () =>
        {
            foreach (FeatureLayer featureLayer in layers)
            {
                using (Table table = featureLayer.GetTable())
                    using (Datastore datastore = table.GetDatastore())
                {
                    if (datastore is UnknownDatastore)
                        continue;

                    Geodatabase geodatabase = datastore as Geodatabase;
                }
            }
        });
}

7 执行 SQL 语句

csharp 复制代码
// 在底层数据库管理系统上执行原始 SQL 语句。
// 任何 SQL 都是允许的(DDL 或 DML),但不能返回结果
public void ExecuteSQLOnGeodatabase(Geodatabase geodatabase, string statement)
{
    QueuedTask.Run(
        () =>
        {
            DatabaseClient.ExecuteStatement(geodatabase, statement);
        });
}
相关推荐
我是苏苏2 小时前
C#基础:Winform桌面开发中窗体之间的数据传递
开发语言·c#
sun0077002 小时前
mysql索引底层原理
数据库·mysql
workflower5 小时前
MDSE和敏捷开发相互矛盾之处:方法论本质的冲突
数据库·软件工程·敏捷流程·极限编程
Tony小周5 小时前
实现一个点击输入框可以弹出的数字软键盘控件 qt 5.12
开发语言·数据库·qt
lifallen6 小时前
Paimon 原子提交实现
java·大数据·数据结构·数据库·后端·算法
TDengine (老段)6 小时前
TDengine 数据库建模最佳实践
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
Elastic 中国社区官方博客6 小时前
Elasticsearch 字符串包含子字符串:高级查询技巧
大数据·数据库·elasticsearch·搜索引擎·全文检索·lucene
Gauss松鼠会7 小时前
GaussDB应用场景全景解析:从金融核心到物联网的分布式数据库实践
数据库·分布式·物联网·金融·database·gaussdb
守城小轩7 小时前
Chromium 136 编译指南 - Android 篇:开发工具安装(三)
android·数据库·redis
尽兴-7 小时前
如何将多个.sql文件合并成一个:Windows和Linux/Mac详细指南
linux·数据库·windows·sql·macos