Rss & SiteMap

Foxtable(狐表) http://www.foxtable.com

新一代数据库软件,完美融合Access、Foxpro、Excel、vb.net之优势,人人都能掌握的快速软件开发工具!
共12 条记录, 每页显示 10 条, 页签: [1] [2]
[浏览完整版]

标题:关于动态添加关联的问题

1楼
布莱克朱 发表于:2011/11/29 22:47:00

   老大,因为我的项目关联比较多,影响到打开速度问题,所以我想改用动态关联.一下代码是我放在窗口事件里面执行,代码写的对不对?我执行好像有一些问题.

 

If Relations.Contains("A") Then
Relations.Delete("A")
Else
Relations.Add("A",DataTables("办公用品领用单").DataCols("系统单号"),DataTables("办公用品领用单明细").DataCols("系统单号"))
End If

 

还有就是我窗口有个窗口表本来是绑定这个关联表的,现在动态了以后,这个表的绑定是怎样的?


Tables("办公用品领用单_Table1").DataSource = Tables("办公用品领用单.办公用品领用单明细").DataTable

 

 

另外,还有这样的做法,对原来关联的加载,关联的锁定,关联的删除,同步的效果是不是一样的?请回复,我如果测试可行,我就用代码来做关联了,不然速度有问题.

2楼
狐狸爸爸 发表于:2011/11/29 23:02:00

呵呵,你还是要确认到底是不是关联的原因吧。

 

如果是的:

 

1、正常建立关联,设计表的时候,将Table绑定到关联表。

2、删除关联,需要的时候,先创建关联:

 

Relations.Add("A",DataTables("办公用品领用单").DataCols("系统单号"),DataTables("办公用品领用单明细").DataCols("系统单号"))
Forms("XXX").Open()

 

这样窗口打开的时候,关联表已经存在,就自动绑定了。

 

3、至于同步锁定,同步更新,同步删除,这些不需要关联一样可以做到。

例如在没有建立关联的时候要同步删除,只需将父表的BeforeDeleteDataRow事件代码设置为:

Datatables("子表名称").DeleteFor("子表关联列 = '" & e.DataRow("父表关联列") & "'")

 

一行代码就实现了同步关联删除的功能。同步锁定和同步更新也一样简单。

3楼
狐狸爸爸 发表于:2011/11/29 23:49:00

实际上窗口设计也一样,我可以加载表B,在表A设计表B的窗口,绑定到表B各列,然后删除表B.

需要使用表B的时候,再动态加载表B,打开之前在表A中设计的表B的窗口即可。

4楼
blackzhu 发表于:2011/11/30 7:55:00
以下是引用狐狸爸爸在2011-11-29 23:49:00的发言:

实际上窗口设计也一样,我可以加载表B,在表A设计表B的窗口,绑定到表B各列,然后删除表B.

需要使用表B的时候,再动态加载表B,打开之前在表A中设计的表B的窗口即可。

    老大,这个我明白.今后的思路之一.

    但是表B如果有表事件代码咋办?还是要加载的,没有代码到是可以的.

5楼
blackzhu 发表于:2011/11/30 7:56:00
因为除了表,还有窗口,代码没有多少,就是关联多一点,所以应该是关联的问题.
6楼
blackzhu 发表于:2011/11/30 7:59:00

3、至于同步锁定,同步更新,同步删除,这些不需要关联一样可以做到。

例如在没有建立关联的时候要同步删除,只需将父表的BeforeDeleteDataRow事件代码设置为:

Datatables("子表名称").DeleteFor("子表关联列 = '" & e.DataRow("父表关联列") & "'")

 

 

也就是说锁定等同步的工作的代码现在已经做的不能用了,要写条件的代码.明白了,和我现在用的虚拟关联一个道理.

7楼
blackzhu 发表于:2011/11/30 8:02:00
、正常建立关联,设计表的时候,将Table绑定到关联表。

2、删除关联,需要的时候,先创建关联:

 

Relations.Add("A",DataTables("办公用品领用单").DataCols("系统单号"),DataTables("办公用品领用单明细").DataCols("系统单号"))
Forms("XXX").Open()

 

 

 这个不明白,程序是不是这样的,第一步先建立一个关联,然后是在窗口建立一个表,然后将关联绑定,然后在删除那个关联.

 

Relations.Add("A",DataTables("办公用品领用单").DataCols("系统单号"),DataTables("办公用品领用单明细").DataCols("系统单号"))
  也就是说,这个关联不能放在窗口事件中,要单独做按钮处理?

8楼
狐狸爸爸 发表于:2011/11/30 8:26:00

既然窗口中的Table绑定到了这个关联表,那么肯定要在打开窗口前建立关联,具体在哪里,取决于设计需求。

 

对于一个超大型的系统,一般是两个思路:

 

1、分成不同的项目,例如销售、生产、财务、人士、仓管,共享一个数据库,各项目只加载自己的表,但是菜单中会有切换到其他项目的按钮,这是常规的设计方式,难度低。

2、如果要整合成一个项目,可以做一两个内部表,所有窗口都可以设计在内部表中,真实数据全部采用外部表,外部表本身、关联、表达式列都可以在运行过程中动态生成,这是非常规的设计,对于开发者要求高。

 

Foxtable是灵活的,不单单是窗口中的Table控件可以动态生成,可以根据需要随意加载不同表的数据,主表一样可以随意生成或卸载,随意加载不同表的数据,甚至数据源都可以动态切换。
单单一个动态加载不同表数据,Foxtable就提供了很多方法:

 

http://www.foxtable.com/help/topics/1929.htm

http://www.foxtable.com/help/topics/1930.htm

http://www.foxtable.com/help/topics/1279.htm

http://www.foxtable.com/help/topics/2335.htm

http://www.foxtable.com/help/topics/2335.htm

http://www.foxtable.com/help/topics/0695.htm

http://www.foxtable.com/help/topics/1907.htm

http://www.foxtable.com/help/topics/1919.htm

 

目前看来:

1、为了方便所有窗口集中在一个内部表设计,以前否决的窗口管理器加上分类的建议应该采纳。

2、应该加一个可以动态绑定到关联表的方法。

 

9楼
blackzhu 发表于:2011/11/30 8:32:00

目前看来:

1、为了方便所有窗口集中在一个内部表设计,以前否决的窗口管理器加上分类的建议应该采纳。

2、应该加一个可以动态绑定到关联表的方法。

 

 

 这个好!

10楼
blackzhu 发表于:2011/11/30 8:36:00
1、分成不同的项目,例如销售、生产、财务、人士、仓管,共享一个数据库,各项目只加载自己的表,但是菜单中会有切换到其他项目的按钮,这是常规的设计方式,难度低。   我自己的就是采取的这个办法.但是现在这个是人家要求的.唉! 动态数据的加载这个我都懂.
共12 条记录, 每页显示 10 条, 页签: [1] [2]

Copyright © 2000 - 2018 foxtable.com Tel: 4000-810-820 粤ICP备11091905号

Powered By Dvbbs Version 8.3.0
Processed in .03516 s, 2 queries.