供求信息 | 产品库 | 公司库 | 电子样本 | 模具技术市场 | 热流道 | 标准件 | 加工中心 | 模具材料 | 二手模具 | 塑料制品人才中心 | 展会中心 | 专利中心 | 会员中心 | 企业视频 | 英语字典 | 模具论坛 | 专业书店 | 网络硬盘 | 采购商服务中心

今日导读
返回中国塑料模具网资讯中心首页技术文献软件教程AutoCAD > 正文

在AutoCAD环境下与数据库间的互联技术

来源:网络 作者: 发布时间:2008-01-17

摘要 本文阐述了在液压CAD系统中,针对AutoCAD R13 for Windows二次开发环境下,利用其内部ASI接口技术进行程序设计,实现与Visual Foxpro 3.0之间进行数据交换的方法。
  关键词:AutoCAD 二次开发 接口 数据交换

1 引言

  数据交换是CAD的核心技术,可以说没有数据的有效交换,就没有CAD优越性的充分发挥。在AutoCAD环境下进行CAD软件二次开发时,如何实现各模块间数据的有效交换,如何解决各类不同软件间的接口问题以及如何实现图形实体与非图形实体数据的联系,是二次开发CAD系统解决的关键问题。
  本文着重讨论了AutoCAD R13 C4 for Windows环境下与Visual Foxpro 3.0之间进行的数据交换的ASI (AutoCAD SQL Interface)程序设计方法,并具体应用于液压系统的CAD软件中。

2 AutoCAD的开发与数据库的访问

  象其他流行软件一样,Autodesk公司在AutoCAD R13内部提供了与外部数据库相互联系的机制。AutoCAD本身含有ASI(AutoCAD SQL Interface)、ASE(AutoCAD SQL Extension)和DBMS(Database Manager System)驱动程序几部分。AutoCAD与数据库文件之间进行数据交换的示意图如图所示。

AutoCAD与数据库文件之间数据交换示意图

  ASI遵循ANSI/ISOSQL标准,是用于从AutoCAD中访问外部数据库的函数集。用ASI建立的应用程序,均可通过AutoCAD的开发应用系统;C语言开发的ADS,Visual C++4.0开发的ARX或其内部所自带的AutoLISP语言连接到AutoCAD系统中,同时可以在不同的数据库驱动程序支持下对不同的数据库进行数据的存取交换。
  ASE是一组命令集,可将SQL连接到AtuoCAD系统中。其实质就是利用ASI建立的ADS/ARX的应用程序。使用 ASE可以在AutoCAD内部对外部数据库中的数据文件的记录和字段进行查询和修改等操作,可以将数据关联到图形实体和非图形实体(如哑图中尺寸参数替换和明细表等)上,实现图形和数据间的双向查询,并可以实现在图形中动态跟踪显示数据。
  AutoCAD本身包含一组数据库驱动程序,其中每一个驱动程序都支持自己所连接的一种外部DBMS。其中用ADS/ARX或AutoLISP建立的应用程序,不必考虑DBMS专用的代码应用程序,是用 ASI编程还是用ASE命令编程,其实质都是遵循通用SQL标准的。
  AutoCAD支持的开发语言有Turbo C,Visual Basic 5.0,Visual C/C++4.0和内部拥有AutoLISP语言,其中C,VB通过建立生成ADS的函数,VC生成的是ARX函数,与AutoCAD信息相联系。
  ASE作为AutoCAD内部的一组命令,可用编程方式执行。ASE作为AutoCAD访问数据库的核心具有更直接访问数据库的能力,允许应用程序对多种DBMS,DBMS内的多个数据库,库内的多张表进行数据访问。ASE和ASI可根据需要单独或同时使用。ASE方法在显示属性、编辑、列表框、基于查询等功能方面显得容易实现,但对于复杂的应用程序,就要使用ASI方式编程实现功能。

3 ASI方法的使用

3.1 ASI的支持文件与开发环境
  AutoCAD R13 for windows所支持的ASI编程的文件都存放在缺省的\ACAD\WIN\ASE目录中。
  有ASI目标库(文件后缀为.LIB)如asiatm80.lib;ASI头文件(asi.h含ASI的通用定义)、(asierr.h包含返回出错代码值的含义)、(asiappl.h含主要的AutoCAD SQL结构查询语言的头文件)、(asisdata.h含C++的用户接口定义)。
  用ASI编制的应用程序,可用的编译器有:Borland C/C++4.0、Microsoft C/C++7.0、Microsoft Visual C++4.0以上版本等。
3.2 利用ASI与数据库交互处理的实现过程步骤
  ● 连通数据库:通过asiinitsql,adsinitdrv,asiconnect分别对ASI指定的DBMS驱动程序进行初始化,登录到所指定的数据库。
  ● 打开一个通讯句柄:这可通过调用asicompile函数来实现。在ASI程序中,每条SQL语句都通过一个通讯句柄来进行处理。
  ● 编译SQL语句:通过调用asicompile函数来实现。
  ● 执行SQL语句:用asiiexecute函数执行SQL语句。
  ● 查询和处理数据:逐行查询结果,选取当前行,进行数据处理。所需的函数有:asifetch获得光标所在的当前行;asicoldsc获得一列的说明;asidelete删除当前行;asiupdate更换当前行,等函数。
  ● 关闭通讯句柄:用asichandle函数关闭语句处理的句柄,并释放句柄。
  ● 断开与数据库的连接:调用asidisconnect函数,断开登录的数据库;调用asitemdrv函数,终止驱动程序;调用asitemrsql函数,终止程序接口。
  上述每一过程可用ASI的出错代码处理函数进行错误信息处理,用asierr获得一条出错代码,用asierrmsg函数获得一条出错信息。

4 实例说明

  本例给出一个由Visual Foxpro3.0环境下,建立起来的液压系统软件包设计中的顺序阀数据库文件SXFLIB.DBF,其数据结构如下表所示。

论坛】【收藏此页】【关闭

免责申明:本网转载作品均注明出处,如转载作品侵犯作者署名权,并非出于本网故意,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如涉及作品内容、版权和其它问题,请在30日内与本网联系,我们将在第一时间删除内容或提供稿费!

产品推荐
会员推荐
Name  Type Diameter Pressure Flux Scale
顺序阀 X-F*

共2页: 上一页 1 [2] 下一页

Google