Foxtable(狐表)用户栏目专家坐堂 → 6月27日更新,请记住这一天,从此众菜鸟也能秒杀资深程序员


  共有22819人关注过本帖平板打印复制链接

主题:6月27日更新,请记住这一天,从此众菜鸟也能秒杀资深程序员

帅哥哟,离线,有人找我吗?
狐狸爸爸
  1楼 | 信息 | 搜索 | 邮箱 | 主页 | UC


加好友 发短信
等级:管理员 帖子:47448 积分:251054 威望:0 精华:91 注册:2008/6/17 17:14:00
6月27日更新,请记住这一天,从此众菜鸟也能秒杀资深程序员  发帖心情 Post By:2009/6/27 16:09:00 [只看该作者]

Foxtable提供的功能,让菜鸟也能设计出专业的录入、查询、统计界面,也能轻松地设计出各种报表和单据。
但是之前Foxtable有一个硬伤,使得菜鸟永远无法超越资深程序员。
今天这个硬伤不复存在。

 

直接统计后台数据


如果数据量非常大,例如上百万甚至千万级别的记录,那么全部加载到内存是不可能的,所以Foxtable提供了动态加载数据的功能,使得在程序的运行过程中,也能随时根据需要加载符合条件的数据,这让Foxtable管理超大型数据库成为可能。


但是这有一个问题,动态加载部分数据是没问题的,但是很多时候,我们的统计是针对所有数据的,而Foxtable的分组统计和交叉统计默认都是针对已经加载的数据的,如果我要统计所有数据,难道需要将一百万甚至一千万记录全部加载到Foxtable?显然这是不可能的。


对于熟练掌握SQL语言的用户来说,这不是问题,直接自己编写SQL语句来统计即可;但实际上,SQL语言虽然入门容易,但是精通是很难的,对于一些复杂的统计,即使是一些非常资深的程序员,也不见得能够在短时间内写出合理高效的SQL语句来,何况是普通用户呢?

到目前为止,我接触的人中,也只有reachtone可以纯火炉青地运用SQL语言,写出一些让人瞠目结舌的统计语句来。


为此GroupTableBuilder和CrossTableBuilder都提供了一个名为FromServer的逻辑属性,只需将此属性设为True,即可直接统计后台数据。


例如:


Dim
g As New GroupTableBuilder("统计表1", DataTables("订单"))
g.Groups.AddDef(
"产品")
g.Totals.AddDef(
"数量")
g.FromServer =
True
g.Build()

MainTable
= Tables("统计表1"
)


上述代码能否自动生成最高效的SQL语句,来对后台数据进行统计。
对于一些复杂的统计,GroupTableBuilder和CrossTableBuilder生成的SQL语句,会比最资深的程序员写出来的SQL语句还要高效。

如果通过菜单统计,且需要直接统计后台数据,可以选中下图所示的选项:


此主题相关图片如下:1080.gif
按此在新窗口浏览图片

你还可以利用这个界面自动生成代码,不过是单击几次鼠标而已。
[此贴子已经被作者于2009-6-27 19:46:41编辑过]

 回到顶部
总数 23 1 2 3 下一页