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()
{
try
{
IWorkspaceFactory2 sdeFac = new SdeWorkspaceFactoryClass();
IPropertySet propertySet = GetProSet(false);
IWorkspace workspace = sdeFac.Open(propertySet, 0);
}
catch(Exception ex)
{
}
}
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));
}
}