VC语言

本类阅读TOP10

·VC++下使用ADO编写数据库程序
·VC++ 学习笔记(二)
·Windows消息大全
·每个开发人员现在应该下载的十种必备工具
·在2000和xp下,隐藏进程,VC6.0测试通过!!!
·用Visual C++打造IE浏览器(1)
·Netmsg 局域网聊天程序
·教你用VC6做QQ对对碰外挂程序
·VC++学习笔记(四)
·VC++中经常使用的函数!~~

分类导航
VC语言Delphi
VB语言ASP
PerlJava
Script数据库
其他语言游戏开发
文件格式网站制作
软件工程.NET开发
关于数据库被锁定的问题及其解决方案

作者:未知 来源:月光软件站 加入时间:2005-2-28 月光软件站

在使用MFC和ODBC操作数据库时,分别映射了不同的表生成不同的CRecordset类,但在使用时出现了数据库被锁定的情况。

解决方案,不要用CRecordset的默认构造函数(无参数),因为这样做的话,每个继承自CRecordset的子类对象在生成时都会被mfc框架自动构造然后传一个CDatabase对象给它,这样的话,有多少个CRecordset子类对象,就有多少个CDatabase对象,在使用时容易竞争数据库资源,虽然在程序里面是先Close掉了一个CRecordset子类对象,再Open另一个CRecordset,但在系统内部,同一个进程里的这个也许还没有完全close掉,还处于锁定状态,另外一个连接数据库的请求就来了,通过在两个CRecordset子类对象使用(Open AddNew Update Close)之间加入Sleeptime(足够长的时间))可以有效解决这种锁定的做法就印证了这种猜测。所以我们自己生成一个CDatabase对象,每个CRecordset子类对象生成时都使用该对象做为参数传入构造函数。这样,无论有多少CRecordset子类(它们都映射自同一个数据库),都只有一个CDatabase对象,不存在竞争资源,不但解决了锁定,还大大加快了程序的运行速度!




相关文章

相关软件




月光软件程序下载编程文档电脑教程网站设计网址导航网络文学游戏天地幽默笑话生活休闲写作范文安妮宝贝
电脑技术编程开发网络专区谈天说地情感世界游戏元素分类游戏热门游戏体育运动手机专区业余爱好影视沙龙
音乐天地数码广场教育园地科学大观古今纵横谈股论金人文艺术医学保健动漫图酷二手专区地方风情各行各业

月光软件站·版权所有