C#连接ArcSDE的几种方式

一、文件连接

IWorkspaceFactory sdeFac = new SdeWorkspaceFactory();
IWorkspace workspace = sdeFac.OpenFromFile(@"F:\GIS测试数据\aa.sde", 0);  //通过文件连接

二、字符串连接

string connectionString = "DATABASE=orcl;INSTANCE=sde:oracle:LCSDE;USER=sde;PASSWORD=sde;VERSION=sde.DEFAULT";
IWorkspaceFactory2 sdeFac = new SdeWorkspaceFactoryClass();
IWorkspace workspace = sdeFac.OpenFromString(connectionString, 0);

  其中LCSDE为Oracle客户端(32位)配置的服务名

三、直连

  貌似是官方推荐的方式,有以下优势:

   A.直连方式较服务连接方式卸载了20%-40%的负载;
   B.直连方式降低了服务器端内存的需求;
   C.直连方式处理速度更快,在客户机上执行处理;
   D.不需要安装ArcSDE软件。

/// <summary>
/// 连接SDE
/// </summary>
private void ConnectSDE()
{
    IWorkspaceFactory2 sdeFac = new SdeWorkspaceFactoryClass();
    IPropertySet propertySet = GetProSet(false);
    IWorkspace workspace = sdeFac.Open(propertySet, 0);
}

SDE连接属性:

        /// <summary>
        /// 设置SDE连接属性
        /// </summary>
        /// <param name="ChkSdeLinkModle"></param>
        /// <returns></returns>
        public static IPropertySet GetProSet(bool ChkSdeLinkModle)
        {
            //定义一个属性
            IPropertySet Propset = new PropertySetClass();
            if (ChkSdeLinkModle == true) //采用SDE连接
            {
                //设置数据库服务器名
                //Propset.SetProperty("SERVER", "");

                Propset.SetProperty("INSTANCE", "sde:oracle11g:LCSDE"); //sde: oracle11g: 127.0.0.1 / orcl
                Propset.SetProperty("USER", "SDE");//SDE的用户名
                Propset.SetProperty("PASSWORD", "sde");//密码

                //设置数据库的名字,通过直连或者服务连Oracle,连接参数Database都可以为空;通过服务连SQL SEVER时,连接参数Database可以为空,但直连时不能为空,Informi需要设置
                //Propset.SetProperty("DATABASE", "orcl");
                //SDE的版本,在这为默认版本
                //Propset.SetProperty("VERSION", "SDE.DEFAULT");
            }
            else//弹窗连接
            {
                //设置数据库服务器名,如果是本机可以用"sde:oracle:.",会弹出选择数据库对话框,要求填入用户名密码。
                Propset.SetProperty("INSTANCE", "sde:oracle:LCSDE"); 
            }
            return Propset;
        }

四、服务连接

    需要安装和配置ArcSDE,不想装

五、获取连接信息

/// <summary>
/// 从workspace中获取连接信息
/// </summary>
private void GetProFromWk(IWorkspace workspace)
{
    Dictionary<string, object> dic = new Dictionary<string, object>();
    object names, values;
    workspace.ConnectionProperties.GetAllProperties(out names, out values);

    foreach (string name in (string[])names)
    {
        dic.Add(name, workspace.ConnectionProperties.GetProperty(name));
    }
}

 

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值