起步软件技术论坛-X3

 找回密码
 立即注册
搜索
查看: 173|回复: 4

【结】用TSqldataset(dsbMaster.DataSet).open有什么要注意的吗?

[复制链接]
发表于 2009-10-29 16:16:22 | 显示全部楼层 |阅读模式
TSqldataset(dsbMaster.DataSet).SQLFilter := lFilter;
TSqldataset(dsbMaster.DataSet).SQLFiltered := True;
这个是以前别人写的,在前面自动打开了数据集,然后做的过滤,但是这样用 SystemMonitor.exe看会查数据库好几遍,
然后我把InfoBroker上的自动打开信息关闭了,然后在过滤语句后面添加了
dsbMaster.DataSet.Open,发现好像还是会查两次,
然后就用
TSqldataset(dsbMaster.DataSet).Open;替换了,发现查的次数少了,但是我不大清楚这样的写法会不会出别的错误,求教了
回复

使用道具 举报

发表于 2009-10-29 16:32:44 | 显示全部楼层
最好是先TSqldataset(dsbMaster.DataSet).SQLFilter := lFilter;
TSqldataset(dsbMaster.DataSet).SQLFiltered := True;再TSqldataset(dsbMaster.DataSet).open;就像在SQL语句里面先加where条件一样,获取的数据范围会小很多,打开的速度也就快了好多.由于在X3中默认自动设置了窗体打开就打开数据集。所以在很多时候会发现出现n次的情况。
回复 支持 反对

使用道具 举报

 楼主| 发表于 2009-10-29 17:10:52 | 显示全部楼层
就是说我这样打开数据集的话不会对平台提供的其他功能比如输出的列表上分组之类的功能产生影响是吗?
回复 支持 反对

使用道具 举报

发表于 2009-10-29 17:18:00 | 显示全部楼层
yes
回复 支持 反对

使用道具 举报

 楼主| 发表于 2009-10-29 17:20:46 | 显示全部楼层
好的,谢谢,结贴吧
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Justep Inc.

GMT+8, 2025-7-15 04:33 , Processed in 0.037766 second(s), 15 queries .

Powered by Discuz! X3.4

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表