数据加载

任何系统都离不开数据的加载,下边就AE中几种常用的数据加载做一个列举。以便查阅:
1、加载个人数据库
个人数据库是保存在Access中的数据库。其加载方式有两种:通过名字和通过属性加载(也许不只这两种,AE中实现同一功能可以有多种方式)。
A、通过设置属性加载个人数据库。
首先通过IPropertySet接口定义要连接数据库的一些相关属性,在个人数据库中为数据库的路径,例如:
IPropertySet Propset = new PropertySetClass(); 
        Propset.SetProperty("DATABASE",@"D:/test/Ao/data/sh/MapData.mdb" );
     当定义完属性并设置属性后就可以进行打开数据库的操作了,在ArcEngine开发中存在IWorkspaceFactory、IFeatureWorkspace、IFeatureClass、IFeatureLayer等几个常用的用于打开和操作数据空间地物的接口。IWorkspaceFactory是一个用于创建和打开工作空间的接口,它是一个抽象的接口,我们在具体应用时要用对应的工作空间实例化它,如下:
IWorkspaceFactory Fact = new AccessWorkspaceFactoryClass ();
如果我们打开的是SDE数据库就要用SdeWorkspaceFactoryClass实例化Fact。当我们完成了工作空间的实例化后就可以根据上边设置的属性打开对应的Access数据库了。打开方式如下:
         IFeatureWorkspace Workspace = Fact.Open(Propset,0) as IFeatureWorkspace;
打开Access工作空间后接下来的事情是做什么了,很简单,找到对应的地物类,赋给相应的层,通过MapControl控件添加对应的层,然后刷新地图。以下为添加某一层的代码:
        IFeatureClass Fcls = Workspace.OpenFeatureClass("District");
       IFeatureLayer Fly = new FeatureLayerClass();
       Fly.FeatureClass = Fcls;
       MapCtr.Map.AddLayer (Fly);
MapCtr.ActiveView.Refresh();
其中District为地物类的名字,MapCtrAE中MapControl的对象。上边的通过属性设置加载数据空间的方式还可以用于SDE数据库,在SDE数据库加载时会介绍。
以下为通过设置属性加载Access数据库的完整C#代码:
     public void AddAccessDBByPro()
     {
         IPropertySet Propset = new PropertySetClass(); 
         Propset.SetProperty("DATABASE",@"D:/test/Ao/data/sh/MapData.mdb" );
         IWorkspaceFactory Fact = new AccessWorkspaceFactoryClass ();
         IFeatureWorkspace Workspace = Fact.Open(Propset,0) as IFeatureWorkspace;
         IFeatureClass Fcls = Workspace.OpenFeatureClass ("District");
         IFeatureLayer Fly = new FeatureLayerClass();
         Fly.FeatureClass = Fcls;
         MapCtr.Map.AddLayer(Fly);
         MapCtr.ActiveView.Refresh();
}
B、通过数据库名字加载个人数据库
在这我先把完整的代码写出来,让您先跟上边的代码做个对比。以下为完整的代码:
public void AddAccessDBByName()
      {
         IWorkspaceName pWorkspaceName = new WorkspaceNameClass() ;
         pWorkspaceName.WorkspaceFactoryProgID ="esriDataSourcesGDB.AccessWorkspaceFactory";
         pWorkspaceName.PathName = @"D:/test/Ao/data/sh/MapData.mdb";
         IName n = pWorkspaceName as IName ;
         IFeatureWorkspace Workspace = n.Open() as IFeatureWorkspace;
         IFeatureClass Fcls = Workspace.OpenFeatureClass ("District");
         IFeatureLayer Fly = new FeatureLayerClass();
         Fly.FeatureClass = Fcls;
         MapCtr.Map.AddLayer (Fly);
         MapCtr.ActiveView.Refresh();
}
细心的人已经注意到,打开Access工作空间后接下来的代码是一样的,都是找到对应的地物类,赋给相应的层,通过MapControl控件添加对应的层,然后刷新地图。现在讲解一下上边的代码,首先是创建一个个人数据库工作空间名,在指定工作空间名的ProgID以确定打开的是什么类型的工作空间,例如在打开Access个人数据库时使用的是下边的代码:
IWorkspaceName pWorkspaceName = new WorkspaceNameClass() ;
pWorkspaceName.WorkspaceFactoryProgID = "esriDataSourcesGDB.AccessWorkspaceFactory";
pWorkspaceName.PathName = @"D:/test/Ao/data/sh/MapData.mdb";
属性WorkspaceFactoryProgID可以确保工作空间是AccessWorkspaceFactory,即个人数据库,同时指定要打开数据库的路径。为了打开数据库,我们通过AE的类图可以发现打开工作空间必须使用IName接口(个人认为,不一定正确,可以思考一下看有其他办法没有),所以接着定义IName对象,并把工作空间名转换成IName类型并赋值给IName对象,然后通过IName对象的Open()方法打开相应的工作空间,代码如下:
IName n = pWorkspaceName as IName ;
IFeatureWorkspace Workspace = n.Open () as IFeatureWorkspace;
接下来的事情就是上边提到。
2、加载SDE数据库
什么是SDE数据库?这个问题要详细地讲解将花费大量的时间,但我可以告诉你SDE数据数据库可以是任何关系数据库。ESRI公司为了使空间数据能保存在关系数据库中,并且能很好的查询相关的空间属性而开发的一个中间件,使用SDE能很好的将空间数据保存在关系数据库中。如Orcale SQL Server 等。SDE具体细节的了解请查找相关的资料,这里只介绍怎么连接SDE数据库。SDE数据库的联机分为直接连接和通过SDE连接。当服务器的性能比较好的时候可以采用SDE连接,否则采用直接连接,这样可以减轻服务器的任务。建议采用直接连接,其实,SDE连接方式和直接连接的方式只是一个属性参数设置的问题。跟个人数据库采用属性连接的方式一样,先定义一个属性对象,然后设置属性参数,接着定义一个工作空间并用SdeWorkspaceFactoryClass()实例化它,接着加在加载图层,至于加载图层的代码,与加载个人数据库中图层的方法一样,其实不只加载这两种数据类型,加载其他类型的数据时也是采用相同的方法加载图层,只是工作空间采用不同的实例而已,下边为完整的对吗”//”后的为注析:
public void AddSDELayer(bool ChkSdeLinkModle)
{
     //定义一个属性
     IPropertySet Propset = new PropertySetClass(); 
     if (ChkSdeLinkModle==true) // 采用SDE连接
     { 
         //设置数据库服务器名
         Propset.SetProperty ("SERVER", "zhpzh");
         //设置SDE的端口,这是安装时指定的,默认安装时"port:5151"
         Propset.SetProperty ("INSTANCE", "port:5151");
         //SDE的用户名
         Propset.SetProperty ("USER", "sa");
         //密码
         Propset.SetProperty ("PASSWORD", "sa");
         //设置数据库的名字,只有SQL Server Informix 数据库才需要设置
         Propset.SetProperty ("DATABASE", "sde");
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值