Access交流中心

北京 | 上海 | 天津 | 重庆 | 广州 | 深圳 | 珠海 | 汕头 | 佛山 | 中山 | 东莞 | 南京 | 苏州 | 无锡 | 常州 | 南通 | 扬州 | 徐州 | 杭州 | 温州 | 宁波 | 台州 | 福州 | 厦门 | 泉州 | 龙岩 | 合肥 | 芜湖 | 成都 | 遂宁 | 长沙 | 株洲 | 湘潭 | 武汉 | 南昌 | 济南 | 青岛 | 烟台 | 潍坊 | 淄博 | 济宁 | 太原 | 郑州 | 石家庄 | 保定 | 唐山 | 西安 | 大连 | 沈阳 | 长春 | 昆明 | 兰州 | 哈尔滨 | 佳木斯 | 南宁 | 桂林 | 海口 | 贵阳 | 西宁 | 乌鲁木齐 | 包头 |

关于Access窗体数据源绑定ADODB.Recordset ,频繁 open close 出错的问题?

litao  发表于:2014-07-21 09:08:15  
复制

我的ACCESS2003程序,有多个窗口。数据全部来自SQL2008R2 服务器。

我给每个窗口单独定义了一个ADODB.Recordset。实行读写分离,RS只起到读取、显示数据功能。写入修改数据,由另外的程序完成。

每个窗口都是只读锁定的。

每次刷新窗口都要关闭RS,重新打开,以实现数据刷新。

由于频繁开、关,总是会出现错误。


为防止错误 每次关闭rs,刷新时

都先用:If rs.State Then rs.Close 关闭ADODB.Recordset

再关闭窗体数据源:Set Me.Recordset = Nothing


其实是上个问题:

使用   ADODB.Connection:   "Provider=sqloledb;Server=S总检\SQLchtj;Database=KSCHTJ;Uid=sa;Pwd=12345;"

在设置窗体数据源 Set Me.Recordset = rs 时,

导致:“BOF或EOF中有一个是真”错误!


换 用:ADODB.Connection: "Provider=Microsoft.Access.OLEDB.10.0;Data Provider=SQLOLEDB.1;Persist Security Info=True;Data Source=S总检\SQLchtj;Initial Catalog=测试库;User ID=sa;Password=12345;"
在  rs.open SQLstr, Cn, adOpenStatic, adLockReadOnly  时
导致:“ACCESS程序停止工作”。


错误不是每次都出现,有时能正常运行,有时又出错。

我怀疑是底层的驱动程序有问题。(我是用的win7 64bit)


请问各位老师对此有什么指教?

 

Top
litao 发表于:2014-07-21 09:18:47

我刚才找了一台XP ,测试了一下。问题一样。


当快速点击查询按键时,会出错。

难道是上次查询程序实际上未执行完成,立即进行新的查询会出错?

请教:如何确定查询程序彻底完成(数据传送完毕)了?



litao 发表于:2014-07-21 10:45:41

经过反复测试,最终确定错误出现在: Set Me.Recordset = rs 

当重复进行窗口记录集绑定的时候出错!



renco 发表于:2014-07-21 21:45:29

一般你是用列表形式显示数据时,才会去加载recordset

不仅是你这类情况,你最小化窗体后,再还原,也会是同样的加载出错的问题

这因当是底层窗体这个类设计的数据刷新形式的问题

所以一般使用时,特别是列表形式时,就ListView,ListBox,类似grid等控件来制作

单窗体时,用非绑定



litao 发表于:2014-07-22 10:27:04

renco : 感谢您的回复!

我的数据显示窗口确实是【数据表】模式,Set Me.Recordset = Rs 也是针对它的。

我测试了一下,用ADODB.Recordset ,所有数据运算交由服务器完成,读取数据库速度最快。所以一直希望摆脱本地【连接表】和【查询】。

关于“ListView,ListBox,类似grid等控件。”

我需要将指定的数据集显示出来,请问在ACCESS 中,在哪里选择,怎么添加、使用?

能否请您,给个范本参考?


再次感谢!




litao 发表于:2014-07-23 14:15:57

问题解决:

关闭子窗体,再重新链接子窗体。就可以重新Set Me.Recordset = Rs 了!



杰克 发表于:2017-06-17 23:51:17

当重复进行窗口记录集绑定的时候出错!

我也遇到这个问题了。请问litao,你是怎么解决的?可否赐教?



总记录:6篇  页次:1/1 9 1 :