在c++ builder中使用access数据库既可以在设计期实现,也可以在运行期通过编程实现。下面就以一个简单的例子,来说明在c++ builder中如何使用access数据库。
在设计期使用access数据库
首先新建一个工程,保存单元文件为unit1.cpp,保存工程文件为project1.bpr。假设保存工程文件的路径下已有一个access数据库文件student.mdb,下面需要为该数据库创建一个别名。点击c++ builder的tools选单项,在下拉选单中点击database desktop就进入了c++ builder自带的数据库系统。然后在database desktop的tools项中选择alias manager来为access数据库创建别名。创建别名的方法是:首先点击“new”按钮,然后在弹出对话框的database alias栏内为数据库起一个别名,例如“mydatabase”,在drive type栏选择msaccess;在database name栏内填入access数据库文件的路径及文件名,其余项目可以根据需要填写,然后点击“ok”按钮,会弹出一个是否保存别名设置的对话框,选择“是”,这样数据库别名就创建完成了。
在表单form1中放置一个tdatabase控件database1,并设置以下属性:aliasname属性选择已创建的别名“mydatabase”,databasename属性填写一个应用程序专用的别名,如“app_alias”(无需创建);connected属性选择true,这时会弹出一个数据库登录对话框,如果未设用户名和口令,则直接点击“ok”,如果在创建别名时设有用户名和口令,正确填写后再点击“ok”就可以连接数据库了。
在表单form1中增加一个ttable控件table1并在databasename属性中填写应用程序的专用别名,本例为“app_alias”,tablename属性中选择一个需要的数据表名,active属性设为true。在表单form1中增加一个tdatasource控件datasource1,将其dataset属性设为table1。再增加一个tdbgrid控件dbgrid1和tdbnavigator控件dbnavigator1,将它们的datasource属性都设为datasource1,这样就可以看到access数据库中的内容了,并通过控件dbnavigator1可以对数据库进行一些简单的操作。如果要对数据库进行更多的操作可以通过对table1编程来实现,在此不再赘述。在设计期使用access数据库简单、快捷,但灵活性差一些。
在运行期使用access数据库
在运行期使用access数据库,在表单form1中除了以上控件外,还需增加一个bde会话期对象,即tsession控件session1。将autosessionname属性设为true,然后在form1的oncreate事件函数中加入以下代码:
ansistring app_path,alias_1,name_1;
app_path=extractfilepath(paramstr(0));
//取得应用程序的路径
alias_1="mydatabase2";
//access数据库别名
name_1="database name="+app_path+"123.mdb";
if(!session1->isalias(alias_1))
//数据库别名不存在
{
tstringlistdataname=new tstringlist();
dataname->add(name_1);
session1->addalias(alias_1,"msaccess",dataname);//创建别名
delete dataname;
session1->close();
}
database1->aliasname=alias_1;
database1->databasename="app_alias";
table1->databasename=database1->databasename;
table1->tablename="xxys";
table1->active=true;
注意:在运行以上程序之前,别忘了进入bde administrator将msaccess驱动配置中的dll32由iddao32.dll改为idda3532.dll,并保存这个配置。
为了使程序运行得更流畅,可以在database1的onlogin事件函数中加入以下代码:
loginparams->values["password"]="";
loginparams->values["username"]="";
这样在运行程序时就不会弹出数据库登录的对话框了。
以上程序在windows95操作系统,c++ builder 3下调试运行通过。
Java Asp PHP .Net XML C/C++ CGI VB Jsp J2ee J2se J2me EJB Servlet Tomcat Resin Struts Weblogic Eclipse ANT GUI JMS Web servise IDEA Webphere Hibernate Spring Jboss Applet Swing Socket Javamail Perl Ajax P2P 安全 模式 框架 测试 开源 游戏
Windows XP Windows 2000 Windows 2003 Windows Me Windows 9.x Linux UNIX 注册表 操作系统 服务器 应用服务器