一个C++Builder5的InterBase组件问题

mingcb 2000-07-24 12:43:00
以下程序的Button1Click在运行第二遍(即按钮的第二次点击)出错:“unsuccessful metadata update
object TMP_TJ is in use”,异常类是:“EIBInterBaseError”,原因何在?
望大侠们帮帮忙!

在Form1中有IBDatabase1.IBTransaction1.IBSQL1.IBTable1.IBDataSet1五个IB组件和一个
Button1按钮组件,InterBase数据库中有两个表:
BM_SP:BH smallint not null primary key,MC varchar(30),DY varchar(6),D1 smallint
TMP_TJ:BH smallint not null primary key,MC varchar(30),DY varchar(6)

Form1的单元程序如下:
void __fastcall TForm1::Button1Click(TObject *Sender)
{
Form1->IBTable1->TableName="TMP_TJ";

if (Form1->IBTable1->Exists) {
Form1->IBSQL1->SQL->Clear();
Form1->IBSQL1->SQL->Add("drop table TMP_TJ");
Caption="1111111111111";
Form1->IBSQL1->ExecQuery();
Caption="2222222222222";
Form1->IBTransaction1->CommitRetaining();
}
//----------------------------------
Caption="333333333";
Form1->IBSQL1->SQL->Clear();
Form1->IBSQL1->SQL->Add("create table TMP_TJ (BH smallint not null primary key,MC varchar(30),DY varchar(6),D1 smallint)");
Form1->IBSQL1->ExecQuery();
Form1->IBTransaction1->CommitRetaining();
Caption="444444444444";
//------------------------------
Form1->IBSQL1->SQL->Clear();
Form1->IBSQL1->SQL->Add("insert into TMP_TJ (BH,MC,DY) select BH,MC,DY from BM_SP");
Form1->IBSQL1->ExecQuery();
Caption="555555555555";
//Form1->IBTransaction1->CommitRetaining();
Caption="666666666666";
//----------------------------------
Form1->IBDataSet1->Active=false;
Form1->IBDataSet1->SelectSQL->Clear();
Form1->IBDataSet1->RefreshSQL->Clear();
Form1->IBDataSet1->InsertSQL->Clear();
Form1->IBDataSet1->ModifySQL->Clear();
Form1->IBDataSet1->DeleteSQL->Clear();
Form1->IBDataSet1->SelectSQL->Add("select * from TMP_TJ");
Form1->IBDataSet1->RefreshSQL->Add("select * from TMP_TJ where BH=:BH");
Form1->IBDataSet1->InsertSQL->Add("insert into TMP_TJ (BH,MC,DY,D1) values(:BH,:MC,:DY,:D1)");
Form1->IBDataSet1->ModifySQL->Add("update TMP_TJ set BH=:BH,MC=:MC,DY=:DY,D1=:D1 where BH=:OLD_BH");
Form1->IBDataSet1->DeleteSQL->Add("delete from TMP_TJ where BH=:OLD_BH");
Form1->IBDataSet1->Active=true;
Caption="7777777777";

Form1->IBDataSet1->Active=false;
Form1->IBTransaction1->CommitRetaining();
}
//---------------------------------------------------------------------------

void __fastcall TForm1::FormCreate(TObject *Sender)
{
this->IBDatabase1->Connected=true;
this->IBTransaction1->Active=true;
}
...全文
84 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复
本书具有下面的一些特色: (1) 例程精练、实用、完整,易于查找本书的例程丰富,短小精练。在每章的前面部分,以一定的篇幅对基本理论、知识要点等进行论述;然后以经典的例程加以说明;最后对例程进行分析和总结。书中的例程完整,并全部按照章号进行了编号。在随书的光盘中有这些例程的源代码和编译、链接后的可执行文件。读者可以使用随书光盘中的“复制”程序(可执行文件为D5Samples.exe)将例程复制到硬盘的指定位置,也可以通过资源管理器进行复制。另外,对于每个例程都指定了若乾个关键字,可以根据关键字查找相关知识点的例程。 (2) 编程技巧丰富作者将自己在开发程序过程中总结、收集的经验和教训、一些读者在编程过程中遇到的问题等融合在本书中,并且将这些编程技巧尽量独立,便于读者快速查找。 (3) 内容广泛,兼容性强本书几乎涉及了C++Builder编程的所有领域,不仅适用于C++Builder 5,而且也适用于C++Builder 4和C++Builder 3等以前的版本。 (4) 体现了面向对象的技术和软件工程化的思想本书从总体上体现了面向对象程序设计的方法,同时将软件工程化的思想融于其中。 内容编排本书主要分为下面的六个部分: 第一部分 C++Builder编程基础 C++ Builder编程基础包括:C++Builder集成开发环境的介绍和C++语言的关键技术。 第二部分 C++Builder编程通用技术 C++ Builder编程核心技能包括:窗体和组件、菜单、工具栏和状态栏、键盘和鼠标、文件、目录和驱动器以及打印等。 第三部分 C++Builder高级编程技术 C++Builder 高级编程技术包括:数据共享、操作注册表、帮助系统的制作、安装与卸载、多线程应用程序、动态链接库和图形与多媒体等技术。 第四部分 数据库编程数据库编程部分包括:关系数据库、数据库组件InterBase服务器、OLE DB/ADO和Web与数据库等。 第五部分 组件对象模型(COM) 组件对象模型(COM)包括:COM和OLE自动化等内容。 第六部分 分布式程序设计分布式程序设计包括:DCOM、MIDAS、ActiveForm、CORBA与分布式应用程序,以及其他的一些编程方法与技巧。 阅读建议: 对于C++Builder的初学者,可以按顺序进行阅读。如果读者对C++语言有一定的了解,也可以直接从第二部分开始,待使用C++Builder编程有了一定的经验后,再回过头来看看第一部分的内容。对于C++Builder的中级用户,可以按章节顺序阅读、上机,也可以直接挑选感兴趣的章节学习。值得注意的是,第一部分的内容对使用C++语言进行软件开发非常有用,一定要掌握好。对于C++Builder的高级用户,可以直接挑选感兴趣的章节阅读。
本书特色 本书具有下面的一些特色: (1) 例程精练、实用、完整,易于查找本书的例程丰富,短小精练。在每章的前面部分,以一定的篇幅对基本理论、知识要点等进行论述;然后以经典的例程加以说明;最后对例程进行分析和总结。书中的例程完整,并全部按照章号进行了编号。在随书的光盘中有这些例程的源代码和编译、链接后的可执行文件。读者可以使用随书光盘中的“复制”程序(可执行文件为D5Samples.exe)将例程复制到硬盘的指定位置,也可以通过资源管理器进行复制。另外,对于每个例程都指定了若乾个关键字,可以根据关键字查找相关知识点的例程。 (2) 编程技巧丰富作者将自己在开发程序过程中总结、收集的经验和教训、一些读者在编程过程中遇到的问题等融合在本书中,并且将这些编程技巧尽量独立,便于读者快速查找。 (3) 内容广泛,兼容性强本书几乎涉及了C++Builder编程的所有领域,不仅适用于C++Builder 5,而且也适用于C++Builder 4和C++Builder 3等以前的版本。 (4) 体现了面向对象的技术和软件工程化的思想本书从总体上体现了面向对象程序设计的方法,同时将软件工程化的思想融于其中。 内容编排本书主要分为下面的六个部分: 第一部分 C++Builder编程基础 C++ Builder编程基础包括:C++Builder集成开发环境的介绍和C++语言的关键技术。 第二部分 C++Builder编程通用技术 C++ Builder编程核心技能包括:窗体和组件、菜单、工具栏和状态栏、键盘和鼠标、文件、目录和驱动器以及打印等。 第三部分 C++Builder高级编程技术 C++Builder 高级编程技术包括:数据共享、操作注册表、帮助系统的制作、安装与卸载、多线程应用程序、动态链接库和图形与多媒体等技术。 第四部分 数据库编程数据库编程部分包括:关系数据库、数据库组件InterBase服务器、OLE DB/ADO和Web与数据库等。 第五部分 组件对象模型(COM) 组件对象模型(COM)包括:COM和OLE自动化等内容。 第六部分 分布式程序设计分布式程序设计包括:DCOM、MIDAS、ActiveForm、CORBA与分布式应用程序,以及其他的一些编程方法与技巧。 阅读建议: 对于C++Builder的初学者,可以按顺序进行阅读。如果读者对C++语言有一定的了解,也可以直接从第二部分开始,待使用C++Builder编程有了一定的经验后,再回过头来看看第一部分的内容。对于C++Builder的中级用户,可以按章节顺序阅读、上机,也可以直接挑选感兴趣的章节学习。值得注意的是,第一部分的内容对使用C++语言进行软件开发非常有用,一定要掌握好。对于C++Builder的高级用户,可以直接挑选感兴趣的章节阅读。

13,825

社区成员

发帖
与我相关
我的任务
社区描述
C++ Builder相关内容讨论区
社区管理员
  • 基础类社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧