数据源Delphi5数据库应用中ODBC数据源的自动管理

odbc数据源  时间:2021-02-27  阅读:()

Delphi5数据库应用中ODBC数据源的自动管理

目录

一、前言

二、原理

1、 ODBC数据源

1注册DSN本身的信息:

2

2、 BDE别名

3、 Itall Shield

4、 Delphi 5.0的注册表控件

三、程序代码

1、 “系统设置” Form

2、代码Option.pas

3、使用系统设置Form

四、小结

正文

摘要本文分析了ODBC数据源设置的原理以及ODBC数据源和Delphi数据库别名的关系。并在此基础上介绍了在Delphi5数据库应用程序安装、运行中如何编程实现ODBC数据源和De lphi数据库别名的设置

关键字 Delphi、数据库、 ODBC

一、前言

Delphi的特色之一就是方便而强大的开发数据库的能力只要轻击几下鼠标填写极少的几行代码就能快速地开发出很有风格的数据库应用程序。编写一个数据应用可以很简单但要在别人的计算机上运行自己的应用却要费一些周折。

首先如果对方的计算机上还没有安装过I npr i se公司的BDE数据库引擎的话那么就必须把BDE和应用程序一起安装到对方的计算机

中。其次应用程序中用到的数据库别名Alias 特别是使用了ODBC数据源连接的数据库别名必须和BDE一起设置。最后如果应用程序使用的数据库其存放路径并不是固定的那么必须根据实际情况进行ODBC和Alias的调整。这些 当然可以在应用程序安装后利用控制面板中ODBC数据源管理和BDE随带的BDE Admini strator通过手工设置。但如此一来一方面会使应用程序大打折扣另一方面不便于普通用户自己的安装和今后工作路径的改动。

和Delphi一起发布的Itall Shield Express可以大大简化安装程序的制作帮助我们完成许多工作。本文将要介绍的便是如何通过Itall Shield和应用程序配合完成安装和运行时的ODBC数据源的自动设置。

二、原理

1、 ODBC数据源

ODBC Open DataBase Conectivity是微软公司制定的标准编程接口只要有相应的ODBC驱动程序就可以通过ODBC连结操作各种不同的数据库。通常通过控制面板中的ODBC Data Source来配置ODBC的数据源。所谓ODBC数据源就是命名的一组信息包括需要连结的数据库所在位置可以是磁盘目录/文件也可以是网络服务器 、对应的ODBC驱动程序以及访问数据库所需的其他相关信息用户可以通过数据源的名称(DS Data Source Names)来指定所需的ODBC连接。

DS按照其保存方式和作用范围分为三种用户DSN、系统DSN和文件DSN。每个文件DSN保存在单独的一个文件中文件可以在网络范围内共享用户DSN保存在注册表中只对当前用户可见系统DSN页保存在注册表中但对系统中的所有用户可见。用户DSN和系统DSN的区别在于用户D SN保存在注册表的HKEY_CURRENT_US ER下而系统DSN保存在HKEY_LOCAL_MACHINE下。

下面 以系统DSN为例说明如何通过修改注册表直接设置ODBC数据源。假定我们要连接的数据库是Acces s97的c:est\auto.mdb(注意用较新的ADO连接Acc ess数据库效率更高这里只是作为一个例子) 数据源的名称为CenterAuto那么可以分为两个步骤

1注册DSN本身的信息:

?在HKEY_LOCAL_MACH I NE\Sof tware\ODB C\ODB C. I NI下添加主键CenterAuto。主键的名称CenterAuto就是数据源的名称。

?向CenterAuto添加键值关键的几项是

键值名键值类型键值含义

Driver字符串(String) C:\WINDOWS\SYSTEM\ODBCJT32.DLL ODBC驱动程序DLL

DBQ字符串(string) c:est\auto.mdb连接的数据库

DriverID双字(Dword) 19H(十六进制数)

FIL字符串(string) MS Access;

?在CenterAuto下添加主键Engines

?在Engines下添加主键Jet

?在Jet下添加键值要是一些配置信息例如

Impl icitCommitSync、 MaxBuffeize、 PageTimeout、 Threads。

关于不同的ODBC数据源的具体设置可以查阅有关书籍不过最简单的方法是在控制面板中设置相应的数据源然后用Regedit 98中或Regedit32 NT中察看一下注册表。

2登记数据源在

HKEY_LOCAL_MACHINE\Sof tware\ODBC\ODBC. INI\ODBC Data Sources下添加键值名CenterAuto类型为字符串键值为“Microsoft AccessDriver (*.mdb)” 。其中键值名指出了DSN必须和前面的对应起来键值则指出了ODBC驱动程序的名称必须是已安装了的。

2、 BDE别名

Delphi 5.0通过BDE实现数据库的操作。在连结数据库时可以直接指出数据库的存放路径也可以通过指定别名实现但前者只能实现对文件型数据库的连接如果要连接服务器上的数据库或ODBC数据源则必须通过别名。

BDE的别名可以用随带的Database Desktop中Alias Manager进行管理也可以在控制面板中用BDE Administrator管理应用程序运行过程中还可以通过Session不可见控件实现动态管理。不过对于ODBC数据源一旦建立了用户DSN或系统DSN那么BDE就会自动建立一个别名别名的名称和DSN的名称是一样的。同样的如果你删除了DSN那么BDE就会删除相应的别名。这就是说在De lphi

5.0中操作ODBC数据源只需要关心DSN的设置就可以了。

3、 Itall Shield

Delphi 5.0附带的Itall Shield不带能够完成BDE的安装工作而且完全支持安装程序对注册表的修改只要简单地在Make RegistryChanges选项下输入需要添加的注册表项目就可以实现在应用程序安装时修改注册表的目的。结合前面介绍的ODBC数据源的设置原理利用这个功能就可以方便地实现在安装时进行DSN的初始设置。

4、 Delphi 5.0的注册表控件

Delphi的TRegistry提供了操作Windows注册表的界面可以在程序中读写注册表中的数据。如果不使用ItallShield通过TRegis

三、程序代码

仍然以CenterAuto数据源为例假设应用程序中有一个“系统设置”选项允许用户改变CenterAuto数据源连接的Auto.mdb的存放路径范例程序如下

1、 “系统设置” Form

2、代码Option.pasunit Option;interfaceuses

Windows Messages SysUtils Classes GraphicsControls Forms Dialogs StdCtrls Registry;type

TOpt ionForm= class(TForm)lbPrompt: TLabel ;edtAutoPath: TEdit;btnOK: TButton;btnCancel: TButton;

OpenDialog: TOpenDialog;btnbrowse: TButton;

procedure FormCreate(Sender: TObject)procedure FormDestroy(Sender: TObject)procedure btnbrowseClick(Sender: TObject)procedure btnOKClick(Sender: TObject)private

{ Private declaratio }

SystemReg:TRegistry; TRegistry在Registry单元中定义publ ic

{ Public declaratio }end;impl ementationprocedure TOptionForm.FormCreate(Sender: TObject)begin

SystemReg:=TRegistry.Create;with SystemReg do

begin

TReg i stry创建后默认的RootKey是HKEY_CURRENT_USERRoot Key:=HKEY_LOCAL_MACHI NE;

打开CenterAuto主键

OpenKey('Software\ODBC\ODBC. INI\CenterAuto'  Fal se)读取原来的数据库含路径edtAutoPath.Text:=ReadString('DBQ'end;end;procedure TOptionForm.FormDestroy(Sender: TObject)beginwith SystemReg dobegin

关闭打开的主键

CloseKey;

创梦网络-新上雅安电信200G防护值内死扛,无视CC攻击,E5 32核高配/32G内存/1TB SSD/100Mbps独享物理机,原价1299,年未上新促销6折,仅779.4/月,续费同价

创梦网络怎么样,创梦网络公司位于四川省达州市,属于四川本地企业,资质齐全,IDC/ISP均有,从创梦网络这边租的服务器均可以****,属于一手资源,高防机柜、大带宽、高防IP业务,另外创梦网络近期还会上线四川眉山联通、广东优化线路高防机柜,CN2专线相关业务。广东电信大带宽近期可以预约机柜了,成都优化线路,机柜租用、服务器云服务器租用,适合建站做游戏,不须要在套CDN,全国访问快,直连省骨干,大网...

速云:深圳独立服务器,新品上线,深港mpls免费体验,多重活动!

速云怎么样?速云是一家国人商家。速云商家主要提供广州移动、深圳移动、广州茂名联通、香港HKT等VDS和独立服务器。目前,速云推出深圳独服优惠活动,机房为深圳移动机房,购买深圳服务器可享受5折优惠,目前独立服务器还支持申请免费试用,需要提交工单开通免费体验试用,次月可享受永久8折优惠,也是需工单申请哦!点击进入:速云官方网站地址活动期限至 2021年7月22日速云云服务器优惠活动:活动1:新购首月可...

弘速云20.8元/月 ,香港云服务器 2核 1g 10M

弘速云元旦活动本公司所销售的弹性云服务器、虚拟专用服务器(VPS)、虚拟主机等涉及网站接入服务的云产品由具备相关资质的第三方合作服务商提供官方网站:https://www.hosuyun.com公司名:弘速科技有限公司香港沙田直营机房采用CTGNET高速回国线路弹性款8折起优惠码:hosu1-1 测试ip:69.165.77.50​地区CPU内存硬盘带宽价格购买地址香港沙田2-8核1-16G20-...

odbc数据源为你推荐
迅雷不能登录为什么我的迅雷不能登陆?还说我网络没连接上,可我明明连上了的优酷路由宝怎么赚钱优酷路由宝是如何赚钱的?bt封杀北京禁用BT下载,是真的吗?为什么?小米手柄小米手柄怎么用?网站推广外链如何做网站推广 ,外链推广的方向在哪里?office2007简体中文版office2007下载安装如何修改ie主页怎么修改IE首页basic语言教程VB语言是啥,咋学,去哪里学...要啥软件米?qq签名设置QQ个性签名设置地理空间数据云在地理空间数据云下载了包含某地区的遥感影像,在BIGEMAP下载了该地区
域名升级访问中 网站域名备案查询 阿里云os 老鹰主机 搜狗抢票助手 cpanel空间 免费个人空间申请 个人域名 阿里云浏览器 双拼域名 cdn加速原理 33456 英雄联盟台服官网 贵阳电信 带宽测试 hostease 深圳主机托管 zcloud reboot 优惠服务器 更多