首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在Delphi中反转Master-Detail连接

在Delphi中反转Master-Detail连接
EN

Stack Overflow用户
提问于 2011-05-22 21:42:03
回答 3查看 1.3K关注 0票数 3

我有2个表,它们是用master-detail连接的。我需要在创建Form2时颠倒连接-这样主表就变成了细节表,而细节表就变成了主表。

我试着这样做,程序编译了,但没有按照我想要的方式工作(之前的连接断开了,但它并没有颠倒,所以程序的工作方式有点像表根本没有连接):

代码语言:javascript
复制
    Form1.ADOTableDetail.MasterSource.Destroy;
    Form1.ADOTableMaster.MasterSource :=  Form1.DataSourceDetail;
    Form1.ADOTableMaster.MasterFields := 'the_field_that_connects_them';

你有什么想法可以让我实现这个目标吗?

EN

回答 3

Stack Overflow用户

回答已采纳

发布于 2011-05-22 22:29:27

不要破坏MasterSource!

为了打破这种关系

代码语言:javascript
复制
Form1.ADOTableDetail.MasterSource:= nil;
Form1.ADOTableDetail.MasterFields:= '';

然后使用此命令重新路由MasterDetail

代码语言:javascript
复制
Form1.ADOTableMaster.MasterSource :=  Form1.DataSourceDetail;
Form1.ADOTableMaster.MasterFields := 'the_field_that_connects_them';

另外,千万不要直接调用.Destroy,而要使用.Free

Free会做一个额外的检查,看看你正在进行的引用是否不是空的,从而防止一些访问冲突。

票数 6
EN

Stack Overflow用户

发布于 2011-05-22 22:36:42

代码语言:javascript
复制
procedure TForm1.ExchangeMasterDetail;
begin
  ADOTableDetail.Close;
  ADOTableMaster.Close;
  ADOTableMaster.MasterFields := ADOTableDetail.IndexFieldNames;
  ADOTableMaster.IndexFieldNames := ADOTableDetail.MasterFields;
  ADOTableDetail.IndexFieldNames := '';
  ADOTableDetail.MasterFields := '';
  ADOTableDetail.MasterSource := nil;
  ADOTableMaster.MasterSource := DataSourceDetail;
  ADOTableDetail.Open;
  ADOTableMaster.Open;
end;
票数 3
EN

Stack Overflow用户

发布于 2013-10-26 06:00:27

只需将Active propriety设置为false即可。

然后做你想做的事情,并将它设置回true

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6088291

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档