页面载入中....
AE中加载个人数据库GDB方法探讨
By  3s4d 发表于 2007-6-5 16:26:00 

下面对AE中加载个人数据库的方法做一个总结:

个人数据库是保存在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为地物类的名字,MapCtr为AE中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;
 
C.直接用路径访问数据库
Dim pWorkspaceFactory As IWorkspaceFactory
              Dim pSWorkspace As IWorkspace
  
              Set pWorkspaceFactory = New AccessWorkspaceFactory
              Set pWorkspace = pWorkspaceFactory.OpenFromFile("D:\data\redarrow.mdb", 0)
 ITable pTable=(pworksapce as IfeatrurWorkspace).open

接下来的事情就是上边提到.


  

 
阅读全文 | 回复(2) | 引用通告 | 编辑
  • 标签:AE 
  • Re:AE中加载个人数据库GDB方法探讨
    By  yumao发表评论于2007-7-24 20:03:00 

    yumao你好,找不到 iworkspace接口是什么意思?是不是没有实例话啊?
     
    个人主页 | 引用 | 返回 | 删除 | 回复
    Re:AE中加载个人数据库GDB方法探讨
    By  night(游客)发表评论于2007-7-17 23:45:00 

    night(游客)你好
    看了你的文章之后受益非浅,我在用AE9.2连接个人数据库时发生一种情况,就是如果定义dim a as Iworkspace 会找不到IWorkSpace 这个接口.
    不知道是什么原因,请大虾指教.
     
    个人主页 | 引用 | 返回 | 删除 | 回复
    发表评论:
    页面载入中....

     
    站点公告
    页面载入中....
    站点日历
    页面载入中....
    最新日志
    页面载入中....
    最新评论
    页面载入中....
    最新留言
    页面载入中....
    友情链接
    站点统计
    页面载入中....
    日志搜索
    用户登陆
    页面载入中....



     
    Powered by Oblog.